Skip to content
Snippets Groups Projects
Select Git revision
  • v3.3.6
  • CyclesPhi-dev default
  • blenderphi-v4.5-v1
  • main protected
  • blender-v4.5-release
  • cycles-v4.5-aurora
  • anari-v4.5
  • anari3
  • anari2
  • anari
  • blender-v4.4-release
  • anary-cycles-device
  • xml-exporter-main
  • blender-v4.3-release
  • temp-sculpt-dyntopo
  • blender-v3.3-release
  • brush-assets-project
  • pr-extensions-tidy-space
  • blender-v4.0-release
  • universal-scene-description
  • blender-v4.1-release
  • v4.4.0
  • v4.2.8
  • v3.6.21
  • v4.2.7
  • v3.6.20
  • v4.2.6
  • v4.3.2
  • v4.2.5
  • v3.6.19
  • v4.3.1
  • v4.3.0
  • v3.6.18
  • v4.2.4
  • v3.6.17
  • v4.2.3
  • v3.6.16
  • v4.2.2
  • v4.2.1
  • v3.6.15
  • v4.2.0
41 results

anim_visualization.c

Blame
  • cs_randperm.c 893 B
    #include "cs.h"
    /* return a random permutation vector, the identity perm, or p = n-1:-1:0.
     * seed = -1 means p = n-1:-1:0.  seed = 0 means p = identity.  otherwise
     * p = random permutation.  */
    csi *cs_randperm (csi n, csi seed)
    {
        csi *p, k, j, t ;
        if (seed == 0) return (NULL) ;      /* return p = NULL (identity) */
        p = cs_malloc (n, sizeof (csi)) ;   /* allocate result */
        if (!p) return (NULL) ;             /* out of memory */
        for (k = 0 ; k < n ; k++) p [k] = n-k-1 ;
        if (seed == -1) return (p) ;        /* return reverse permutation */
        srand (seed) ;                      /* get new random number seed */
        for (k = 0 ; k < n ; k++)
        {
            j = k + (rand ( ) % (n-k)) ;    /* j = rand integer in range k to n-1 */
            t = p [j] ;                     /* swap p[k] and p[j] */
            p [j] = p [k] ;
            p [k] = t ;
        }
        return (p) ;
    }