AlexeyAB
2018-03-19 537d135feba179636e9bbfe296e078d51f59914c
src/utils.c
@@ -3,10 +3,13 @@
#include <string.h>
#include <math.h>
#include <assert.h>
#include "unistd.h"
#include <float.h>
#include <limits.h>
#ifdef WIN32
#include "unistd.h"
#else
#include <unistd.h>
#endif
#include "utils.h"
#pragma warning(disable: 4996)
@@ -123,6 +126,7 @@
    {
        c = next+1;
    }
   if(!next) while ((next = strchr(c, '\\'))) { c = next + 1; }
    c = copy_string(c);
    next = strchr(c, '.');
    if (next) *next = 0;
@@ -282,7 +286,8 @@
        fgets(&line[curr], readsize, fp);
        curr = strlen(line);
    }
    if(line[curr-1] == '\n') line[curr-1] = '\0';
    if(line[curr-2] == 0x0d) line[curr-2] = 0x00;
    if(line[curr-1] == 0x0a) line[curr-1] = 0x00;
    return line;
}
@@ -604,12 +609,13 @@
        max = swap;
    }
    return ((float)rand()/RAND_MAX * (max - min)) + min;
   //return (random_float() * (max - min)) + min;
}
float rand_scale(float s)
{
    float scale = rand_uniform(1, s);
    if(rand()%2) return scale;
    float scale = rand_uniform_strong(1, s);
    if(random_gen()%2) return scale;
    return 1./scale;
}
@@ -625,3 +631,32 @@
    return t;
}
unsigned int random_gen()
{
   unsigned int rnd = 0;
#ifdef WIN32
   rand_s(&rnd);
#else
   rnd = rand();
#endif
   return rnd;
}
float random_float()
{
#ifdef WIN32
   return ((float)random_gen() / (float)UINT_MAX);
#else
   return ((float)random_gen() / (float)RAND_MAX);
#endif
}
float rand_uniform_strong(float min, float max)
{
   if (max < min) {
      float swap = min;
      min = max;
      max = swap;
   }
   return (random_float() * (max - min)) + min;
}