#include "voro++.hh"
using namespace voro;
const double x_min=-6,x_max=6;
const double y_min=-6,y_max=6;
const double z_min=-3,z_max=9;
const double Phi=0.5*(1+sqrt(5.0));
const double phi=0.5*(1-sqrt(5.0));
const int n_x=5,n_y=5,n_z=5;
class wall_initial_shape : public wall {
public:
wall_initial_shape() {
v.init(-2,2,-2,2,-2,2);
v.plane(0,Phi,1);v.plane(0,-Phi,1);v.plane(0,Phi,-1);
v.plane(0,-Phi,-1);v.plane(1,0,Phi);v.plane(-1,0,Phi);
v.plane(1,0,-Phi);v.plane(-1,0,-Phi);v.plane(Phi,1,0);
v.plane(-Phi,1,0);v.plane(Phi,-1,0);v.plane(-Phi,-1,0);
};
bool point_inside(double x,double y,double z) {return true;}
bool cut_cell(voronoicell &c,double x,double y,double z) {
c=v;
return true;
}
bool cut_cell(voronoicell_neighbor &c,double x,double y,double z) {
c=v;
return true;
}
private:
voronoicell v;
};
int main() {
container con(x_min,x_max,y_min,y_max,z_min,z_max,n_x,n_y,n_z,
false,false,false,8);
wall_initial_shape(wis);
con.add_wall(wis);
con.import("pack_irregular");
con.draw_particles_pov("irregular_p.pov");
con.draw_cells_pov("irregular_v.pov");
}