[GRASS-SVN] r36018 - grass/trunk/vector/v.vol.rst

svn_grass at osgeo.org svn_grass at osgeo.org
Sat Feb 21 12:19:17 EST 2009


Author: neteler
Date: 2009-02-21 12:19:17 -0500 (Sat, 21 Feb 2009)
New Revision: 36018

Modified:
   grass/trunk/vector/v.vol.rst/user.h
   grass/trunk/vector/v.vol.rst/user3.c
   grass/trunk/vector/v.vol.rst/user4.c
Log:
Antonio Galea: reduced computational time to 30-40% by skipping unnecessary computations

Modified: grass/trunk/vector/v.vol.rst/user.h
===================================================================
--- grass/trunk/vector/v.vol.rst/user.h	2009-02-21 16:41:19 UTC (rev 36017)
+++ grass/trunk/vector/v.vol.rst/user.h	2009-02-21 17:19:17 UTC (rev 36018)
@@ -14,6 +14,7 @@
 double crsd();
 double crsdr2();
 double crsdd();
+void crs_full();
 int COGRR1();
 int POINT();
 int LINEQS();

Modified: grass/trunk/vector/v.vol.rst/user3.c
===================================================================
--- grass/trunk/vector/v.vol.rst/user3.c	2009-02-21 16:41:19 UTC (rev 36017)
+++ grass/trunk/vector/v.vol.rst/user3.c	2009-02-21 17:19:17 UTC (rev 36018)
@@ -235,6 +235,7 @@
     double wm, dx, dy, dz, dxx, dyy, dxy, dxz, dyz, dzz, h, bmgd1,
 	bmgd2, etar, zcon, r, ww, wz, r2, hcell, zzcell2,
 	etarcell, rcell, wwcell, zzcell;
+    double x_crs,x_crsd,x_crsdd,x_crsdr2;
     int n1, k1, k2, k, i1, l, l1, n4, n5, m, i;
     int NGST, LSIZE, ngstc, nszc, ngstr, nszr, ngstl, nszl;
     int POINT();
@@ -244,6 +245,8 @@
     int bmask = 1;
     static FCELL *cell = NULL;
 
+    int cond1 = (gradient != NULL) || (aspect1 != NULL) || (aspect2 != NULL);
+    int cond2 = (ncurv != NULL) || (gcurv != NULL) || (mcurv != NULL);
 
 #define CEULER .57721566
     /*
@@ -450,25 +453,31 @@
 			    r = sqrt(r2);
 			    etar = (fi * r) / 2.;
 
-			    h = h + b[m] * crs(etar);
-			    /* partial derivatives */
-			    bmgd1 = b[m] * crsd(etar, fi);
+                            crs_full(
+                              etar,fi,
+                              &x_crs,
+                              cond1?&x_crsd:NULL,
+                              cond2?&x_crsdr2:NULL,
+                              cond2?&x_crsdd:NULL
+                            );
+                            h = h + b[m] * x_crs;
+                            if(cond1)
+                            {
+                                   bmgd1 = b[m] * x_crsd;
 			    dx = dx + bmgd1 * xx;
 			    dy = dy + bmgd1 * w[m];
-			    /* dz = dz + bmgd1 * sqrt(wz2[m]); */
 			    dz = dz + bmgd1 * wz1[m];
-			    bmgd2 = b[m] * crsdd(etar, fi);
-			    bmgd1 = b[m] * crsdr2(etar, fi);
-			    dxx = dxx + bmgd2 * xx2 + bmgd1 * xx2;
+                            }
+                            if(cond2)
+                            {
+                                   bmgd2 = b[m] * x_crsdd;
+                                   bmgd1 = b[m] * x_crsdr2;
 			    dyy = dyy + bmgd2 * w2[m] + bmgd1 * w2[m];
 			    dzz = dzz + bmgd2 * wz2[m] + bmgd1 * wz2[m];
 			    dxy = dxy + bmgd2 * xx * w[m] + bmgd1 * xx * w[m];
-			    dxz =
-				dxz + bmgd2 * xx * wz1[m] +
-				bmgd1 * xx * wz1[m];
-			    dyz =
-				dyz + bmgd2 * w[m] * wz1[m] +
-				bmgd1 * w[m] * wz1[m];
+                                   dxz = dxz + bmgd2 * xx * wz1[m] + bmgd1 * xx * wz1[m];
+                                   dyz = dyz + bmgd2 * w[m] * wz1[m] + bmgd1 * w[m] * wz1[m];
+                            }                            
 			}
 			ww = h + wmin;
 			if ((cellinp != NULL) && (cellout != NULL) &&

Modified: grass/trunk/vector/v.vol.rst/user4.c
===================================================================
--- grass/trunk/vector/v.vol.rst/user4.c	2009-02-21 16:41:19 UTC (rev 36017)
+++ grass/trunk/vector/v.vol.rst/user4.c	2009-02-21 17:19:17 UTC (rev 36018)
@@ -145,7 +145,7 @@
     static double a[5] = { 0.254829592, -0.284496736, 1.421413741,
 	-1.453152027, 1.061405429
     };
-    double p = 0.3275911;
+    static double p = 0.3275911;
     double erf, t;
 
 
@@ -167,21 +167,21 @@
  */
 {
 
-    static double a[10];
-    double tp = 1.1283791671 / 2.;
+    static double a[10] = {
+      1.,
+      -1. / 3.,
+      1. / 10.,
+      -1. / 42.,
+      1. / (24. * 9.),
+      -1. / (120. * 11.),
+      1. / (720. * 13.),
+      -1. / (5040. * 15.),
+      1. / (40320. * 17.),
+      -1. / (362880. * 19.),
+    };
+    static double tp = 1.1283791671 / 2.;
     double xx, res;
 
-    a[0] = 1.;
-    a[1] = -1. / 3.;
-    a[2] = 1. / 10.;
-    a[3] = -1. / 42.;
-    a[4] = 1. / (24. * 9.);
-    a[5] = -1. / (120. * 11.);
-    a[6] = 1. / (720. * 13.);
-    a[7] = -1. / (5040. * 15.);
-    a[8] = 1. / (40320. * 17.);
-    a[9] = -1. / (362880. * 19.);
-
     if (x < XA) {
 	xx = x * x;
 	res =
@@ -204,37 +204,24 @@
 }
 
 
+void crs_full(double x, double fi, double *crs, double *crsd, double *crsdr2, double *crsdd){
+    static double a[10] = { 1., -1. / 3., 1. / 10., -1. / 42., 1. / (24. * 9.), -1. / (120. * 11.),
+      1. / (720. * 13.), -1. / (5040. * 15.), 1. / (40320. * 17.), -1. / (362880. * 19.) };
+    static double b[10] = { 0, -2. / 3., 4. / 10., -6. / 42., 8. / (24. * 9.), -10. / (120. * 11.),
+      12. / (720. * 13.), -14. / (5040. * 15.), 16. / (40320. * 17.), -18. / (362880. * 19.) };
+    static double c[10] = { 0, 0, 8. / 10., -24. / 42., 48. / (24. * 9.), -80. / (120. * 11.),
+      120. / (720. * 13.), -168. / (5040. * 15.), 16. * 14. / (40320. * 17.), -18. * 16. / (362880. * 19.) };
+    static double tp = 1.1283791671 / 2.;
+    double xx, r, r2, fi2, fi4, fi8, tmp1, tmp2;
 
-
-double crsd(double x, double fi)
-/*
-   function for first derivatives 
- */
-{
-
-    static double a[10];
-    double tp = 1.1283791671 / 2.;
-    double xx, r, r2, fi2, fi4, res;
-
-    a[1] = -2. / 3.;
-    a[2] = 4. / 10.;
-    a[3] = -6. / 42.;
-    a[4] = 8. / (24. * 9.);
-    a[5] = -10. / (120. * 11.);
-    a[6] = 12. / (720. * 13.);
-    a[7] = -14. / (5040. * 15.);
-    a[8] = 16. / (40320. * 17.);
-    a[9] = -18. / (362880. * 19.);
-
-    r = 2. * x / fi;
-    r2 = r * r;
     fi2 = fi / 2.;
     fi4 = fi2 * fi2;
+    fi8 = fi4 * fi4;
 
     if (x < XA) {
 	xx = x * x;
-	res =
-	    tp * fi4 * (a[1] +
+	*crs =
+	    tp * xx * (a[1] +
 			xx * (a[2] +
 			      xx * (a[3] +
 				    xx * (a[4] +
@@ -243,111 +230,52 @@
 						      xx * (a[7] +
 							    xx * (a[8] +
 								  xx *
-								  a
-								  [9]))))))));
-    }
-    else {
-	res = (2. * tp * exp(-x * x) - (erf(x) / x)) / (2. * r2);
-    }
-    return (res);
-}
-
-double crsdr2(double x, double fi)
-/*
-   function for first derivatives
- */
-{
-
-    static double a[10];
-    double tp = 1.1283791671 / 2.;
-    double xx, r, r2, fi2, fi4, res;
-
-    a[1] = -2. / 3.;
-    a[2] = 4. / 10.;
-    a[3] = -6. / 42.;
-    a[4] = 8. / (24. * 9.);
-    a[5] = -10. / (120. * 11.);
-    a[6] = 12. / (720. * 13.);
-    a[7] = -14. / (5040. * 15.);
-    a[8] = 16. / (40320. * 17.);
-    a[9] = -18. / (362880. * 19.);
-
-    r = 2. * x / fi;
-    r2 = r * r;
-    fi2 = fi / 2.;
-    fi4 = fi2 * fi2;
-
-    if (x < XA) {
-	xx = x * x;
-	res =
-	    tp * fi4 * (a[1] +
-			xx * (a[2] +
-			      xx * (a[3] +
-				    xx * (a[4] +
-					  xx * (a[5] +
-						xx * (a[6] +
-						      xx * (a[7] +
-							    xx * (a[8] +
+                                                                      a[9]))))))));
+	if(crsd!=NULL){
+          *crsd =
+              tp * fi4 * (b[1] +
+                          xx * (b[2] +
+                                xx * (b[3] +
+                                      xx * (b[4] +
+                                            xx * (b[5] +
+                                                  xx * (b[6] +
+                                                        xx * (b[7] +
+                                                              xx * (b[8] +
 								  xx *
-								  a
-								  [9]))))))));
+                                                                    b[9]))))))));
     }
-    else {
-	res = (2. * tp * exp(-x * x) - (erf(x) / x)) / (2. * r2 * r2);
+	if(crsdr2!=NULL){
+	  *crsdr2 = *crsd;
     }
-    return (res);
-}
-
-double crsdd(double x, double fi)
-/*
-   function for second derivatives 
- */
-{
-
-    static double a[10];
-    double tp = 1.1283791671 / 2.;
-    double xx, r, r2, fi8, res;
-
-    a[2] = 8. / 10.;
-    a[3] = -24. / 42.;
-    a[4] = 48. / (24. * 9.);
-    a[5] = -80. / (120. * 11.);
-    a[6] = 120. / (720. * 13.);
-    a[7] = -168. / (5040. * 15.);
-    a[8] = 16. * 14. / (40320. * 17.);
-    a[9] = -18. * 16. / (362880. * 19.);
-
+	if(crsdd!=NULL){
+          *crsdd =
+              tp * fi8 * (c[2] +
+                          xx * (c[3] +
+                                xx * (c[4] +
+                                      xx * (c[5] +
+                                            xx * (c[6] +
+                                                  xx * (c[7] +
+                                                        xx * (c[8] +
+                                                              xx * c[9])))))));
+        }
+    } else {
+        tmp1 = erf(x) / x;
+	*crs = tmp1 / 2. - tp;
+        if((crsd!=NULL)||(crsdr2!=NULL)||(crsdd!=NULL)){
     r = 2. * x / fi;
     r2 = r * r;
-    fi8 = fi * fi * fi * fi / 16.;
-
-    if (x < XA) {
-	xx = x * x;
-	res =
-	    tp * fi8 * (a[2] +
-			xx * (a[3] +
-			      xx * (a[4] +
-				    xx * (a[5] +
-					  xx * (a[6] +
-						xx * (a[7] +
-						      xx * (a[8] +
-							    xx * a[9])))))));
+          tmp2 = exp(-x * x);
     }
-    else {
+        if(crsd!=NULL){ *crsd   = (2. * tp * tmp2 - tmp1) / (2. * r2); }
+	if(crsdr2!=NULL){ *crsdr2 = *crsd / r2; }
 	/* Jarov vzorec */
-	res =
-	    (erf(x) / (x * r2) -
-	     exp(-x * x) * (2 / r2 + fi * fi / 2) * tp) / (r2 * r2);;
+	if(crsdd!=NULL){ *crsdd  = (tmp1 / r2 - tmp2 * (2 / r2 + fi * fi / 2) * tp) / (r2 * r2); }
     }
-    return (res);
+    return;
 }
 
 
 
-
-
-
-
 /*********solution of system of lin. equations*********/
 
 int LINEQS(int DIM1, int N1, int N2, int *NERROR, double *DETERM)



More information about the grass-commit mailing list