[GRASS-SVN] r63485 - grass-addons/grass7/vector/v.surf.nnbathy

svn_grass at osgeo.org svn_grass at osgeo.org
Fri Dec 12 03:22:18 PST 2014


Author: martinl
Date: 2014-12-12 03:22:18 -0800 (Fri, 12 Dec 2014)
New Revision: 63485

Added:
   grass-addons/grass7/vector/v.surf.nnbathy/nnbathy.py
   grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.html
   grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.py
   grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.html
   grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.py
Removed:
   grass-addons/grass7/vector/v.surf.nnbathy/libnnbathy/
   grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy/
   grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy/
Log:
m.surf.nnbathy -> v.surf.nnbathy (step 2)

Copied: grass-addons/grass7/vector/v.surf.nnbathy/nnbathy.py (from rev 63484, grass-addons/grass7/vector/v.surf.nnbathy/libnnbathy/nnbathy.py)
===================================================================
--- grass-addons/grass7/vector/v.surf.nnbathy/nnbathy.py	                        (rev 0)
+++ grass-addons/grass7/vector/v.surf.nnbathy/nnbathy.py	2014-12-12 11:22:18 UTC (rev 63485)
@@ -0,0 +1,165 @@
+import grass.script as grass
+import os
+
+
+class Nnbathy:
+    # base class
+    def __init__(self, options):
+        self._tmpxyz = grass.tempfile()
+        self._xyzout = grass.tempfile()
+        self._tmp = grass.tempfile()
+        self._tmpcat = grass.tempfile()
+        self.options = options
+        self.region()
+        pass
+
+    def region(self):
+        # set the computive region
+        reg = grass.read_command("g.region", flags='p')
+        kv = grass.parse_key_val(reg, sep=':')
+        reg_N = float(kv['north'])
+        reg_W = float(kv['west'])
+        reg_S = float(kv['south'])
+        reg_E = float(kv['east'])
+        nsres = float(kv['nsres'])
+        ewres = float(kv['ewres'])
+
+        # set variables
+        self.cols = int(kv['cols'])
+        self.rows = int(kv['rows'])
+        self.area = (reg_N-reg_S)*(reg_E-reg_W)
+        self.ALG = 'nn'
+
+        # set the working region for nnbathy (it's cell-center oriented)
+        self.nn_n = reg_N - nsres/2
+        self.nn_s = reg_S + nsres/2
+        self.nn_w = reg_W + ewres/2
+        self.nn_e = reg_E - ewres/2
+        self.null = "NaN"
+        self.ctype = "double"
+
+    def compute(self):
+        # computing
+        grass.message('"nnbathy" is performing the interpolation now. \
+                      This may take some time...')
+        grass.verbose("Once it completes an 'All done.' \
+                      message will be printed.")
+
+        # nnbathy calling
+        fsock = open(self._xyzout, 'w')
+        grass.call(['nnbathy',
+                    '-W', '%d' % 0,
+                    '-i', '%s' % self._tmpxyz,
+                    '-x', '%d' % self.nn_w, '%d' % self.nn_e,
+                    '-y', '%d' % self.nn_n, '%d' % self.nn_s,
+                    '-P', '%s' % self.ALG,
+                    '-n', '%dx%d' % (self.cols, self.rows)],
+                   stdout=fsock)
+        fsock.close()
+
+    def create_output(self):
+        # create the output raster map
+        # convert the X,Y,Z nnbathy output into a GRASS ASCII grid
+        # then import with r.in.ascii
+        # 1 create header
+        header = open(self._tmp, 'w')
+        header.write('north: %s\nsouth: %s\neast: %s\nwest: %s\nrows: %s\ncols: %s\ntype: %s\nnull: %s\n\n' %
+                     (self.nn_n, self.nn_s, self.nn_e,  self.nn_w, self.rows, self.cols, self.ctype, self.null))
+        header.close()
+
+        # 2 do the conversion
+        grass.message("Converting nnbathy output to GRASS raster ...")
+        fin = open(self._xyzout, 'r')
+        fout = open(self._tmp, 'a')
+        cur_col = 1
+        for line in fin:
+            parts = line.split(" ")
+            if cur_col == self.cols:
+                cur_col = 0
+                fout.write(str(parts[2]))
+            else:
+                fout.write(str(parts[2]).rstrip('\n')+' ')
+            cur_col += 1
+        fin.close()
+        fout.close()
+
+        # 3 import to raster
+        grass.run_command('r.in.ascii', input=self._tmp,
+                          output=self.options['output'], quiet=True)
+        grass.message("All done. Raster map <%s> created."
+                      % self.options['output'])
+
+    def __del__(self):
+        # cleanup
+        if self._tmp:
+            os.remove(self._tmp)
+        if self._tmpxyz:
+            os.remove(self._tmpxyz)
+        if self._xyzout:
+            os.remove(self._xyzout)
+        if self._tmpcat:
+            os.remove(self._tmpcat)
+
+
+class Nnbathy_raster(Nnbathy):
+    # class for raster input
+    def __init__(self, options):
+        Nnbathy.__init__(self, options)
+        self._load(options)
+
+    def _load(self, options):
+        # load input raster
+        grass.run_command('r.stats', flags='1gn', input=options['input'],
+                          output=self._tmpxyz, quiet=True, overwrite=True)
+
+
+class Nnbathy_vector(Nnbathy):
+    # class for vector input
+    def __init__(self, options):
+        Nnbathy.__init__(self, options)
+        self._load(options)
+
+    def _load(self, options):
+        # load input vector, initial controls
+        if int(options['layer']) == 0:
+            _layer = ''
+            _column = ''
+        else:
+            _layer = int(options['layer'])
+            if options['column']:
+                _column = options['column']
+            else:
+                grass.message('Name of z column required for 2D vector maps.')
+
+        # convert vector to ASCII
+        grass.run_command("v.out.ascii", flags='r', overwrite=1,
+                          input=options['input'], output=self._tmpcat,
+                          format="point", separator="space", precision=15,
+                          where=options['where'], layer=_layer,
+                          columns=_column)
+
+        # edit ASCII file, crop out one column
+        if int(options['layer']) > 0:
+            fin = open(self._tmpcat, 'r')
+            fout = open(self._tmpxyz, 'w')
+            try:
+                for line in fin:
+                    parts = line.split(" ")
+                    fout.write(parts[0]+' '+parts[1]+' '+parts[3])
+            except StandardError, e:
+                grass.fatal_error("Invalid input: %s" % e)
+            fin.close()
+            fout.close()
+        else:
+            grass.message("Z coordinates are used.")
+
+
+class Nnbathy_file:
+    # class for file input
+    def __init__(self, options):
+        self.options = options
+        self._load(options)
+
+    def _load(self, options):
+        # load input file
+        self._tmpxyz = options['file']

Copied: grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.html (from rev 63484, grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy/r.surf.nnbathy.html)
===================================================================
--- grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.html	                        (rev 0)
+++ grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.html	2014-12-12 11:22:18 UTC (rev 63485)
@@ -0,0 +1,80 @@
+<h2>DESCRIPTION</h2>
+
+<em>r.surf.nnbathy</em> is an interface between the
+external <em>nnbathy</em> utility and <em>GRASS</em>.
+<em>nnbathy</em> is a surface interpolation program provided with
+<a href="https://code.google.com/p/nn-c/">nn</a> - a natural neighbor
+interpolation library, written by Pavel Sakov.
+
+<p>
+<em>r.surf.nnbathy</em> provides 3 interpolation algorithms. According to
+<em>nn</em> library documentation these are: Delaunay interpolation
+(<b>alg=l</b>), Watson's algortithm for Sibson natural neighbor
+interpolation (<b>alg=nn</b>) and Belikov and Semenov's algorithm for
+non-Sibsonian natural neighbor interpolation (<b>alg=ns</b>). For performing
+the underlaying Delaunay triangulation in all cases <em>nnbathy</em> uses
+<em>triangle</em> software by
+<a href="http://www.cs.berkeley.edu/~jrs/">Jonathan Richard Shewchuk</a>.
+
+<p>
+The <b>output</b> raster map is a continous surface interpolated from the
+<b>input</b> data.
+
+<h2>NOTES</h2>
+
+<em>nnbathy</em>, if built with '-DNN_SERIAL' (default as of nn 1.85), is
+able to create a grid of virtually any size. It interpolates and writes one
+output point at a time only. This eliminates the necessity to hold the whole
+output array in memory. However, even then all the input points are still
+held in the memory.
+
+<ol>
+<li>Requires <em>GRASS</em> 7 and <em>nnbathy</em> 1.76 or greater.</li>
+<li>Build <em>nnbathy</em> according to instructions provided with its source
+code and put it somewhere in your $PATH.</li>
+<li>The output raster map extent and resolution match the region settings at
+which the script was started.</li>
+<li>The output raster map non-NULL area is limited to the convex hull
+encompassing all the non-NULL input cells.</li>
+<li>The output is double precision floating point raster map (DCELL).</li>
+<li>Natural neighbor is a an <em>exact</em> interpolation algorithm, so all
+non-NULL input points have their value exactly preserved in the output.</li>
+<li>There is circa 0.2 KB memory overhead per each <em>input</em> cell.
+However, the <em>output</em> grid can be of any size, if <em>nnbathy</em> is
+built with -DNN_SERIAL switch.</li>
+<li><em>r.surf.nnbathy</em> creates 3 temporary files: ASCII x,y,z lists of
+the input points and output cells, and the output list converted into GRASS ASCII
+format. Then it makes a GRASS raster map from the latter - and only then it
+removes the 3 temp files, when the script terminates. Thus, at the script
+run time several times more disk space might be required, than the final
+GRASS raster map would actually occupy.</li>
+</ol>
+
+<h2>EXAMPLE</h2>
+
+TODO
+
+<h2>REFERENCES</h2>
+
+<ul>
+  <li><a href="https://code.google.com/p/nn-c/">nnbathy</a> library by Pavel Sakov</li>
+</ul>
+
+<h2>SEE ALSO</h2>
+
+<em>
+  <a href="v.surf.nnbathy.html">v.surf.nnbathy</a>
+</em> 
+
+
+<h2>AUTHOR</h2>
+
+Adam Laza, Czech Technical University in Prague (mentor: Martin Landa)
+
+<p>
+based on v.surf.nnbathy from GRASS 6 by<br>
+Hamish Bowman, Otago University, New Zealand<br>
+Based on <em>r.surf.nnbathy</em> by Maciej Sieczka<br>
+
+<p>
+<i>Last changed: $Date$</i>

Copied: grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.py (from rev 63484, grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy/r.surf.nnbathy.py)
===================================================================
--- grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.py	                        (rev 0)
+++ grass-addons/grass7/vector/v.surf.nnbathy/r.surf.nnbathy.py	2014-12-12 11:22:18 UTC (rev 63485)
@@ -0,0 +1,73 @@
+#!/usr/bin/env python
+############################################################################
+#
+# MODULE:     r.surf.nnbathy
+#
+# AUTHOR(S):  Adam Laza (mentor: Martin Landa)
+#             (based on v.surf.nnbathy from GRASS 6)
+#
+# PURPOSE:    Interpolate raster surface using the "nnbathy" natural
+#             neighbor interpolation program.
+#
+# COPYRIGHT:  (c) 2014 Adam Laza, and the GRASS Development Team
+#
+# LICENSE:    This program is free software under the GNU General Public
+#             License (>=v2). Read the file COPYING that comes with
+#             GRASS for details.
+#
+#############################################################################
+#
+# NOTES:
+#
+# 1. Requires nnbathy executable v 1.75 or later. Follow the instruction in
+#    html manual page to obtain it.
+#
+# 2. When creating the input raster map, make sure it's extents cover
+#    your whole region of interest, the cells you wish to interplate on are
+#    NULL, and the resolution is correct. Same as most GRASS raster modules
+#    this one is region sensitive too.
+
+#%Module
+#% description: Interpolates a raster map using the nnbathy natural neighbor interpolation program.
+#% keywords: vector
+#% keywords: surface
+#% keywords: interpolation
+#% keywords: natural
+#% keywords: neighbor
+#%end
+#%option G_OPT_R_INPUT
+#% key: input
+#% type: string
+#% description: Name of input raster map
+#% guisection: Input data
+#% required : yes
+#%end
+#%option G_OPT_R_OUTPUT
+#% key: output
+#% description: Name of output raster map
+#%end
+#%option
+#% key: algorithm
+#% type: string
+#% options: l,nn,ns
+#% answer: nn
+#% descriptions: l;Linear;nn;Sibson natural neighbor;ns;Non-Sibsonian natural neighbor
+#% description: Settings
+#%end
+
+import os
+import sys
+
+from grass.script.core import parser
+import grass.script as grass
+
+def main():
+    sys.path.insert(1, os.path.join(os.path.dirname(sys.path[0]), 'etc', 'nnbathy'))
+    from nnbathy import Nnbathy_raster
+    obj = Nnbathy_raster(options)
+    obj.compute()
+    obj.create_output()
+
+if __name__ == "__main__":
+    options, flags = parser()
+    main()

Copied: grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.html (from rev 63484, grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy/v.surf.nnbathy.html)
===================================================================
--- grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.html	                        (rev 0)
+++ grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.html	2014-12-12 11:22:18 UTC (rev 63485)
@@ -0,0 +1,79 @@
+<h2>DESCRIPTION</h2>
+
+<em>v.surf.nnbathy</em> is an interface between the
+external <em>nnbathy</em> utility and <em>GRASS</em>.
+<em>nnbathy</em> is a surface interpolation program provided with
+<a href="https://code.google.com/p/nn-c/">nn</a> - a natural neighbor
+interpolation library, written by Pavel Sakov.
+
+<p>
+<em>v.surf.nnbathy</em> provides 3 interpolation algorithms. According to
+<em>nn</em> library documentation these are: Delaunay interpolation
+(<b>alg=l</b>), Watson's algortithm for Sibson natural neighbor
+interpolation (<b>alg=nn</b>) and Belikov and Semenov's algorithm for
+non-Sibsonian natural neighbor interpolation (<b>alg=ns</b>). For performing
+the underlaying Delaunay triangulation in all cases <em>nnbathy</em> uses
+<em>triangle</em> software by
+<a href="http://www.cs.berkeley.edu/~jrs/">Jonathan Richard Shewchuk</a>.
+
+<p>
+The <b>output</b> raster map is a continous surface interpolated from the
+<b>input</b> or <b>file</b> data.
+
+<h2>NOTES</h2>
+
+<em>nnbathy</em>, if built with '-DNN_SERIAL' (default as of nn 1.85), is
+able to create a grid of virtually any size. It interpolates and writes one
+output point at a time only. This eliminates the necessity to hold the whole
+output array in memory. However, even then all the input points are still
+held in the memory.
+
+<ol>
+<li>Requires <em>GRASS</em> 7 and <em>nnbathy</em> 1.76 or greater.</li>
+<li>Build <em>nnbathy</em> according to instructions provided with its source
+code and put it somewhere in your $PATH.</li>
+<li>The output raster map extent and resolution match the region settings at
+which the script was started.</li>
+<li>The output raster map non-NULL area is limited to the convex hull
+encompassing all the non-NULL input cells.</li>
+<li>The output is double precision floating point raster map (DCELL).</li>
+<li>Natural neighbor is a an <em>exact</em> interpolation algorithm, so all
+non-NULL input points have their value exactly preserved in the output.</li>
+<li>There is circa 0.2 KB memory overhead per each <em>input</em> cell.
+However, the <em>output</em> grid can be of any size, if <em>nnbathy</em> is
+built with -DNN_SERIAL switch.</li>
+<li><em>v.surf.nnbathy</em> creates 4 temporary files: ASCII x,y,z lists of
+the input points and output cells, and the output list converted into GRASS ASCII
+format. Then it makes a GRASS raster map from the latter - and only then it
+removes the 3 temp files, when the script terminates. Thus, at the script
+run time several times more disk space might be required, than the final
+GRASS raster map would actually occupy.</li>
+</ol>
+
+<h2>EXAMPLE</h2>
+
+TODO
+
+<h2>REFERENCES</h2>
+
+<ul>
+  <li><a href="https://code.google.com/p/nn-c/">nnbathy</a> library by Pavel Sakov</li>
+</ul>
+
+<h2>SEE ALSO</h2>
+
+<em>
+  <a href="r.surf.nnbathy.html">r.surf.nnbathy</a>
+</em> 
+
+<h2>AUTHOR</h2>
+
+Adam Laza, Czech Technical University in Prague (mentor: Martin Landa)
+
+<p>
+Based on v.surf.nnbathy from GRASS 6 by:<br>
+Hamish Bowman, Otago University, New Zealand<br>
+Based on <em>r.surf.nnbathy</em> by Maciej Sieczka<br>
+
+<p>
+<i>Last changed: $Date$</i>

Copied: grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.py (from rev 63484, grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy/v.surf.nnbathy.py)
===================================================================
--- grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.py	                        (rev 0)
+++ grass-addons/grass7/vector/v.surf.nnbathy/v.surf.nnbathy.py	2014-12-12 11:22:18 UTC (rev 63485)
@@ -0,0 +1,109 @@
+#!/usr/bin/env python
+############################################################################
+#
+# MODULE:     v.surf.nnbathy
+#
+# AUTHOR(S):  Adam Laza (mentor: Martin Landa)
+#             (based on v.surf.nnbathy from GRASS 6)
+#
+# PURPOSE:    Interpolate raster surface using the "nnbathy" natural
+#             neighbor interpolation program.
+#
+# COPYRIGHT:  (c) 2014 Adam Laza, and the GRASS Development Team
+#
+# LICENSE:    This program is free software under the GNU General Public
+#             License (>=v2). Read the file COPYING that comes with
+#             GRASS for details.
+#
+#############################################################################
+#
+# NOTES:
+#
+# 1. Requires nnbathy executable v 1.75 or later. Follow the instruction in
+#    html manual page to obtain it.
+#
+# 2. When creating the input raster map, make sure it's extents cover
+#    your whole region of interest, the cells you wish to interplate on are
+#    NULL, and the resolution is correct. Same as most GRASS raster modules
+#    this one is region sensitive too.
+
+#%Module
+#% description: Interpolates a raster map using the nnbathy natural neighbor interpolation program.
+#% keywords: vector
+#% keywords: surface
+#% keywords: interpolation
+#% keywords: natural
+#% keywords: neighbor
+#%end
+#%option G_OPT_V_INPUT
+#% key: input
+#% type: string
+#% description: Name of input vector points map
+#% guisection: Input data
+#% required : no
+#%end
+#%option G_OPT_V_FIELD
+#% key: layer
+#% label: Layer number
+#% description: If set to 0, z coordinates are used. (3D vector only)
+#% guisection: Selection
+#%end
+#%option G_OPT_F_INPUT
+#% key: file
+#% description: Containing x,y,z data as three space separated columns
+#% guisection: Input data
+#% required : no
+#%end
+#%option G_OPT_R_OUTPUT
+#% key: output
+#% description: Name of output raster map
+#%end
+#%option G_OPT_DB_COLUMN
+#% description: Name of the attribute column with values to be used for approximation (if layer>0)
+#% guisection: Settings
+#%end
+#%option G_OPT_DB_WHERE
+#% guisection: Selection
+#%end
+#%option
+#% key: algorithm
+#% type: string
+#% options: l,nn,ns
+#% answer: nn
+#% descriptions: l;Linear;nn;Sibson natural neighbor;ns;Non-Sibsonian natural neighbor
+#% description: Settings
+#%end
+
+import sys
+import os
+
+from grass.script.core import parser
+import grass.script as grass
+
+
+def main():
+    sys.path.insert(1, os.path.join(os.path.dirname(sys.path[0]), 'etc', 'nnbathy'))
+    from nnbathy import Nnbathy_vector, Nnbathy_file
+    # initial controls
+    if (options['input'] and options['file']):
+        grass.fatal("Please specify either the 'input' \
+                    or 'file' option, not both.")
+
+    if not(options['input'] or options['file']):
+        grass.message("Please specify either the 'input' or 'file' option.")
+
+    if (options['file'] and os.path.isfile(options['file'])):
+        grass.message("File "+options['file']+" does not exist.")
+
+    # vector or file input?
+    if (options['input']):
+        obj = Nnbathy_vector(options)
+    else:
+        obj = Nnbathy_file(options)
+
+    obj.compute()
+    obj.create_output()
+
+if __name__ == "__main__":
+    options, flags = parser()
+    main()



More information about the grass-commit mailing list