1#define PINK_MAX_RANDOM_ROWS (30) 2#define PINK_RANDOM_BITS (24) 3#define PINK_RANDOM_SHIFT ((sizeof(long)*8)-PINK_RANDOM_BITS) 4 5typedef struct 6{ 7 long pink_rows[PINK_MAX_RANDOM_ROWS]; 8 long pink_running_sum; /* Used to optimize summing of generators. */ 9 int pink_index; /* Incremented each sample. */ 10 int pink_index_mask; /* Index wrapped by ANDing with this mask. */ 11 float pink_scalar; /* Used to scale within range of -1.0 to +1.0 */ 12} pink_noise_t; 13 14void initialize_pink_noise( pink_noise_t *pink, int num_rows ); 15float generate_pink_noise_sample( pink_noise_t *pink ); 16