#include <nd-random.h> // Dimension of the vector to generate #define DIMENSION 10 // Minimum angle from the axis of the cone #define THETA_MIN M_PI/4 // Maximum angle from the axis of the cone #define THETA_MAX M_PI/3 int main () { // Initialize random number generator. gsl_rng_env_setup(); gsl_rng* r = gsl_rng_alloc(gsl_rng_default); // Allocate vector to be generated. gsl_vector *x = gsl_vector_alloc(DIMENSION); // Allocate and initialize central axis of cone. gsl_vector *axis = gsl_vector_alloc(DIMENSION); gsl_vector_set_all(axis, 1/sqrt(DIMENSION)); // Generate random vector on spherical cap of hollow cone. hollow_cone_random_vector(r, axis, THETA_MIN, THETA_MAX, x); // Print out generated vector. gsl_vector_fprintf(stdout, x, "%g"); // Free allocated memory. gsl_vector_free(axis); gsl_vector_free(x); gsl_rng_free(r); return 0; }