#include <CGAL/trace.h>
#include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
#include <CGAL/Polyhedron_3.h>
#include <CGAL/IO/Polyhedron_iostream.h>
#include <CGAL/Surface_mesh_default_triangulation_3.h>
#include <CGAL/make_surface_mesh.h>
#include <CGAL/Implicit_surface_3.h>
#include <CGAL/IO/output_surface_facets_to_polyhedron.h>
#include <CGAL/Poisson_reconstruction_function.h>
#include <CGAL/Point_with_normal_3.h>
#include <CGAL/property_map.h>
#include <CGAL/IO/read_xyz_points.h>
#include <CGAL/compute_average_spacing.h>
#include <vector>
#include <fstream>
typedef CGAL::Point_with_normal_3<Kernel> Point_with_normal;
typedef std::vector<Point_with_normal> PointList;
typedef CGAL::Polyhedron_3<Kernel> Polyhedron;
int main(void)
{
    
    FT sm_angle = 20.0; 
    FT sm_radius = 30; 
    FT sm_distance = 0.375; 
    
    
    
    
    PointList points;
    std::ifstream stream("data/kitten.xyz");
    if (!stream ||
                              stream,
                              std::back_inserter(points),
                              CGAL::make_normal_of_point_with_normal_pmap(PointList::value_type())))
    {
      std::cerr << "Error: cannot read file data/kitten.xyz" << std::endl;
      return EXIT_FAILURE;
    }
    
    
    
    
    Poisson_reconstruction_function function(points.begin(), points.end(),
                                             CGAL::make_normal_of_point_with_normal_pmap(PointList::value_type()) );
    
    
    if ( ! function.compute_implicit_function() ) 
      return EXIT_FAILURE;
    
                                                       6 );
    
    
    Point inner_point = function.get_inner_point();
    Sphere bsphere = function.bounding_sphere();
    FT radius = 
std::sqrt(bsphere.squared_radius());
 
    
    
    FT sm_sphere_radius = 5.0 * radius;
    FT sm_dichotomy_error = sm_distance*average_spacing/1000.0; 
                      Sphere(inner_point,sm_sphere_radius*sm_sphere_radius),
                      sm_dichotomy_error/sm_sphere_radius);
    
                                                        sm_radius*average_spacing,  
                                                        sm_distance*average_spacing); 
    
    STr tr; 
    C2t3 c2t3(tr); 
                            surface,                              
                            criteria,                             
    if(tr.number_of_vertices() == 0)
      return EXIT_FAILURE;
    
    std::ofstream out("kitten_poisson-20-30-0.375.off");
    Polyhedron output_mesh;
    out << output_mesh;
    return EXIT_SUCCESS;
}