palate 0.3.9

File type detection combining tft and hyperpolyglot
Documentation
model Tuto3D

global {
  int nb_cells <-100;
  int environmentSize <-100;
  geometry shape <- cube(environmentSize);  
  init { 
    create cells number: nb_cells { 
      location <- {rnd(environmentSize), rnd(environmentSize), rnd(environmentSize)};       
    } 
  }  
} 
    
species cells skills: [moving3D] {  
    rgb color;
    list<cells> neighbors;
    int offset;
    
    reflex move {
      do wander;    
    }   
    
    reflex computeNeighbors {
      neighbors <- cells select ((each distance_to self) < 10);
    }
        
    aspect default {
        draw sphere(environmentSize*0.01) color:#orange;
        loop pp over: neighbors {
            draw line([self.location,pp.location]);
        }   
    }
}


experiment Tuto3D  type: gui {
  parameter "Initial number of cells: " var: nb_cells min: 1 max: 1000 category: "Cells" ;
  output {
    display View1 type:opengl background:rgb(10,40,55){
      graphics "env"{
        draw cube(environmentSize) color: #black empty:true;    
      }
      species cells;
    }
  }  
}