Skip to content
Snippets Groups Projects
Select Git revision
  • d55ac4da2bae18c3623c8ffe656dc04330241c04
  • master default protected
  • blender2.8
  • collada
  • topbar
  • greasepencil-object
  • temp-modifier-rm-cddm
  • blender2.8-workbench
  • hair_guides
  • fracture_modifier
  • temp-tab_drag_drop
  • asset-engine
  • soc-2017-normal-tools
  • cycles_embree
  • userpref_redesign
  • fluid-mantaflow
  • blender-v2.79b-release
  • cycles_embree3
  • temp-object-multi-mode
  • cycles_bvh8
  • blender-v2.79a-release
  • v2.79b
  • v2.79a
  • v2.79
  • v2.79-rc2
  • v2.79-rc1
  • v2.78c
  • v2.78b
  • v2.78a
  • v2.78
  • v2.78-rc2
  • v2.78-rc1
  • v2.77a
  • v2.77
  • v2.77-rc2
  • v2.77-rc1
  • v2.76b
  • v2.76a
  • v2.76
  • v2.76-rc3
  • v2.76-rc2
41 results

properties_render.py

Blame
  • cs_house.c 743 B
    #include "cs.h"
    /* create a Householder reflection [v,beta,s]=house(x), overwrite x with v,
     * where (I-beta*v*v')*x = s*e1.  See Algo 5.1.1, Golub & Van Loan, 3rd ed. */
    double cs_house (double *x, double *beta, csi n)
    {
        double s, sigma = 0 ;
        csi i ;
        if (!x || !beta) return (-1) ;          /* check inputs */
        for (i = 1 ; i < n ; i++) sigma += x [i] * x [i] ;
        if (sigma == 0)
        {
            s = fabs (x [0]) ;                  /* s = |x(0)| */
            (*beta) = (x [0] <= 0) ? 2 : 0 ;
            x [0] = 1 ;
        }
        else
        {
            s = sqrt (x [0] * x [0] + sigma) ;  /* s = norm (x) */
            x [0] = (x [0] <= 0) ? (x [0] - s) : (-sigma / (x [0] + s)) ;
            (*beta) = -1. / (s * x [0]) ;
        }
        return (s) ;
    }