home *** CD-ROM | disk | FTP | other *** search
/ SGI Developer Toolbox 6.1 / SGI Developer Toolbox 6.1 - Disc 4.iso / src / demos / audio / drive / Bspline.c++ < prev    next >
Encoding:
C/C++ Source or Header  |  1994-08-02  |  1.2 KB  |  48 lines

  1. /*
  2.  * Copyright 1992-1993, 1994, Silicon Graphics, Inc.
  3.  * All Rights Reserved.
  4.  *
  5.  * This is UNPUBLISHED PROPRIETARY SOURCE CODE of Silicon Graphics, Inc.;
  6.  * the contents of this file may not be disclosed to third parties, copied or
  7.  * duplicated in any form, in whole or in part, without the prior written
  8.  * permission of Silicon Graphics, Inc.
  9.  *
  10.  * RESTRICTED RIGHTS LEGEND:
  11.  * Use, duplication or disclosure by the Government is subject to restrictions
  12.  * as set forth in subdivision (c)(1)(ii) of the Rights in Technical Data
  13.  * and Computer Software clause at DFARS 252.227-7013, and/or in similar or
  14.  * successor clauses in the FAR, DOD or NASA FAR Supplement. Unpublished -
  15.  * rights reserved under the Copyright Laws of the United States.
  16.  */
  17. #include <math.h>
  18. #include <stdio.h>
  19.  
  20. static int c(int n, int k);
  21.  
  22.  
  23. static int c(int n, int k)
  24. {
  25.     switch(n)
  26.     {
  27.         case 2:
  28.             switch(k)
  29.             {
  30.                 case 0: return 1;
  31.                 case 1: return 2;
  32.                 case 2: return 1;
  33.             }
  34.     
  35.         default: fprintf(stderr,"c: unknown n = %d, k = %d\n",n,k);
  36.     }
  37. }
  38.  
  39.  
  40. // returns bspline basis
  41. // n is degree (cubic is 3, quadratic 2)
  42. // k is index of control pt 0 thru degree
  43. // u is 0.0-1.0
  44. float bsbasis(int n, int k, float u)
  45. {
  46.     return c(n,k)*powf(u,(float)k)*powf(1.0-u,(float)(n-k));
  47. }
  48.