Changes between Initial Version and Version 1 of GSoC/2021


Ignore:
Timestamp:
02/02/21 18:50:52 (4 years ago)
Author:
wenzeslaus
Comment:

2020 content

Legend:

Unmodified
Added
Removed
Modified
  • GSoC/2021

    v1 v1  
     1
     2{{{
     3#!html
     4<!-- direct usage of HTML enables to use the big @ characters at the same line as images -->
     5<!-- derived from the HTML taken from GRASS User Mediawiki -->
     6<!-- needs to be changed every year (GSoC link and maybe picture) -->
     7<!-- also check and update links at the bottom -->
     8<p>
     9<a href="https://grass.osgeo.org" rel="nofollow">
     10<img alt="Grasslogo vector small.png" src="/grass/raw-attachment/wiki/GSoC/2014/Grasslogo_vector_small.png" width="110" height="123" />
     11</a>
     12 <font size="+3"> @ </font>
     13<a href="https://summerofcode.withgoogle.com/" rel="nofollow">
     14<img alt="500px-GSoC2016Logo.jpg​" src="/grass/raw-attachment/wiki/GSoC/2016/500px-GSoC2016Logo.jpg"/>
     15</a>
     16<font size="+3"> @ </font>
     17<a href="https://wiki.osgeo.org/wiki/Google_Summer_of_Code_2020" rel="nofollow">
     18<img alt="OSGeo logo" src="/grass/raw-attachment/wiki/GSoC/2018/osgeo_logo.png" width="300" height="97" /></a>
     19</p>
     20}}}
     21
     22
     23= GRASS Google Summer of Code 2020 =
     24
     25[[TOC]]
     26
     27
     28== About ==
     29
     30 * [https://wiki.osgeo.org/wiki/Google_Summer_of_Code_2020 The OSGeo GSoC 2020 main page]
     31 * [https://summerofcode.withgoogle.com/ Official GSoC page at Google]
     32
     33== Ideas ==
     34
     35''Post your ideas here or to the [https://lists.osgeo.org/listinfo/grass-dev grass-dev mailing list] if you want to discuss them more. To edit this wiki, you need to [https://trac.osgeo.org/grass/login login] with an [https://www.osgeo.org/community/getting-started-osgeo/osgeo_userid/ OSGeo Userid]; read also some [wiki:TracLinks help] for using trac.''
     36
     37If you are a student you can suggest a new idea or pick up an existing one in any case write about it to [https://lists.osgeo.org/listinfo/grass-dev grass-dev mailing list].
     38
     39''You are invited as well to have a close look at (and re-suggest!) ideas from previous years ([https://grasswiki.osgeo.org/wiki/GRASS_SoC_Ideas_2007 2007], [https://grasswiki.osgeo.org/wiki/GRASS_SoC_Ideas_2008#Ideas 2008],
     40[https://grasswiki.osgeo.org/wiki/GRASS_SoC_Ideas_2009#Ideas 2009], [https://grasswiki.osgeo.org/wiki/GRASS_SoC_Ideas_2010#Ideas 2010],
     41[https://grasswiki.osgeo.org/wiki/GRASS_SoC_Ideas_2011#Ideas 2011], [https://grasswiki.osgeo.org/wiki/GRASS_SoC_Ideas_2012#Ideas 2012],
     42[https://grasswiki.osgeo.org/wiki/GRASS_SoC_Ideas_2013#Ideas 2013], [wiki:/GSoC/2014 2014], [wiki:/GSoC/2015 2015], [wiki:/GSoC/2016 2016],
     43[wiki:/GSoC/2017 2017],
     44[wiki:/GSoC/2018 2018],
     45[wiki:/GSoC/2018 2019])
     46which have not yet been implemented.
     47You can also look at accepted GRASS GSoC [wiki:GSoC projects from previous years] for an idea of scope.''
     48
     49''Include "GRASS GIS" in the title of our idea to easily distinguish ideas and projects inside OSGeo.''
     50
     51''Some bigger ideas may have their own pages, so you can link them here. The pages can be either independent if the page already exists (e.g. `wxGUIDevelopment/SingleWindow`), or more preferably subpages of this page if the idea is (re-)developed for this GSoC. In the later case, use the word "idea" in the page name to distinguish the idea page (e.g. `GSoC/2020/CoolGRASSProjectIdea`) from the possible student project page (e.g. `GSoC/2020/CoolGRASSProject`).''
     52
     53
     54
     55=== Title of idea ===
     56
     57Description here
     58
     59* Requirements:
     60* Mentor:
     61* Proposed by:
     62* Rating:
     63* Expected Outcomes: 
     64* Test of skills:
     65* Other:
     66
     67=== Seamless integration of GRASS GIS and Jupyter Notebooks ===
     68
     69* Start of GRASS GIS inside a script or a notebook is currently too cumbersome.
     70* Maps do not allow panning and other interactions.
     71* There are examples how to use Jupyter Notebooks with GRASS GIS, but they need to be improved.
     72* Requirements: Basic knowledge of GRASS GIS scripting and IPython/Jupyter Notebooks, Python, !JavaScript
     73* Mentor: Vaclav Petras
     74* Co-mentor:
     75* Rating: easy
     76* Expected Outcomes:  IPython/Jupyter Notebooks related to grass; some new functions in grass library to show data/tables on IPython/Jupyter Notebooks
     77* Test of skills: Write a testsuite for a GRASS GIS command, more info [https://grass.osgeo.org/grass72/manuals/libpython/gunittest_testing.html here]
     78
     79=== New Startup Window for GRASS GIS ===
     80
     81A new startup window (the first window you get when you start GRASS GIS) needs to be improved. There is already a detailed discussion at the [wiki:wxGUIDevelopment/New_Startup New Startup Trac Wiki page] with a well-defined roadmap in the [wiki:wxGUIDevelopment/New_Startup#PragueRoadmap Prague Roadmap] section.
     82
     83* Requirements: Python, wxPython, GUI design
     84* Mentor: Anna Petrasova
     85* Co-mentors: Vaclav Petras, Martin Landa
     86* Proposed by: Vaclav Petras
     87* Expected Outcomes: Streamlined and understandable startup using GUI
     88* Test of skills: Implement any (smaller) part of [wiki:wxGUIDevelopment/New_Startup#PragueRoadmap Prague Roadmap] and submit as a PR on !GitHub
     89* Other: Since there is already a detailed roadmap, the proposals are expected to provide additional information on top of that including precise timing, discussion of dependencies between individual steps, differences from the current state, and evaluation of the current source code.
     90
     91=== Improved color management in GRASS GIS ===
     92
     93Current color management of raster and vector maps has several issues:
     94* Interactive editing of colors is rather limited: #3370
     95* We can't easily specify discrete color intervals (e.g. [http://soliton.vm.bytemark.co.uk/pub/cpt-city/cb/seq/tn/BuPu_09.png.index.html this ramp]) for floating point data unless we reclass first, legend does not display that correctly
     96* [https://trac.osgeo.org/grass/query?status=!closed&keywords=~colors and others...]
     97
     98A new color editing widget could be developed that would be integrated in r.colors, r3.colors, v.colors, t.rast.colors. It would allow simple editing of breaks (manual and automatic). Better support for discrete color tables for floating point data needs to be developed.
     99
     100* Requirements: Python, wxPython, possibly some C
     101* Mentor: Anna Petrasova, Vaclav Petras
     102* Proposed by: Anna Petrasova
     103* Rating: medium
     104* Expected Outcomes: More user-friendly color management
     105* Test of skills: [https://trac.osgeo.org/grass/query?status=!closed&keywords=~colors and others...]
     106
     107=== Enhance 3D rendering capabilities in GRASS GIS ===
     108
     109Current 3D rendering capabilities in GRASS GIS (called NVIZ) are quite powerful, but many important features are missing.
     110The current implementation is rather old and needs to be updated with more recent technologies.
     111The following points (fixes and new features) should be addressed:
     112* fix rendering raster and vector data with transparency
     113* faster rendering of point clouds
     114* implement text rendering (for scale bars for example)
     115* review and fix problems with current rendering of 3D vectors
     116* possible new features would include volume rendering (ray casting for example), so far we can visualize only isosurfaces or slices of 3D rasters
     117* adding axes
     118
     119* Requirements: C, OpenGL
     120* Mentor: Anna Petrasova
     121* Co-mentor: Vaclav Petras
     122* Proposed by: Anna Petrasova
     123* Rating: medium
     124* Expected Outcomes: reliable on-screen and off-screen 3D rendering on most platforms
     125* Test of skills: #2076, #3743
     126
     127=== GRASS GUI: Single window layout ===
     128Currently, GRASS GIS GUI (wxGUI) has one Layer Manager window and one or more Map Display windows. This multiple window layout can sometimes be problematic and is not common. This project would try to develop an optional single window layout, similarly to [https://docs.gimp.org/2.8/en/gimp-concepts-main-windows.html GIMP]. This project would include:
     129* detailed design of the behavior of current components + mockups
     130* refactoring some of the wxGUI components to untangle them and make them reusable
     131* implementing the actual layout and its behavior while keeping the multiple window layout working
     132
     133* Requirements: Python, wxPython
     134* Mentor: Anna Petrasova, Vaclav Petras
     135* Proposed by: Anna Petrasova
     136* Rating: medium
     137* Expected Outcomes: enable switching between single- and multiple-window layout
     138* Test of skills: Develop a simple wxPython application, which would allow to switch between these two modes. This should demonstrate student knows wxPython and general GUI design.
     139
     140=== New easy-to-use CLI and API for GRASS GIS ===
     141
     142 * Requirements:
     143  * Language: Python
     144  * Proposal: Student needs to show sufficient understanding of the GRASS GIS Database structure and significantly extend on text below in terms of more concrete formulation of ideas and identification of missing and existing parts.
     145 * Mentors: Vaclav Petras
     146 * Co-mentors:
     147 * Proposed by: Vaclav Petras
     148 * TL;DR: Make running of GRASS GIS modules as easy as it is to run GDAL commands.
     149  * `grass run r.slope.aspect elevation=elevation.tiff slope=slope.tiff aspect=aspect.tiff`
     150  * CLI like GDAL has.
     151  * No GRASS Database, Location, Mapset to deal with.
     152  * No import, export from user perspective.
     153  * Reasonable defaults for things like region.
     154  * CLI and API still allows user to specify any of the above.
     155 * GRASS GIS requires GRASS GIS Database, Location and Mapset to be set up to maintain data consistency, efficiency and security. Unfortunately, this is cumbersome when GRASS GIS is not the primary tool user is using.
     156 * There are different ways for calling GRASS modules without starting iterative GRASS session:
     157  * Modules executed with the `--exec` interface (see [https://grass.osgeo.org/grass74/manuals/grass7.html#batch-jobs-with-the-exec-interface the grass7 manual page] >=7.2)
     158  * `GRASS_BATCH_JOB`: same as newer `--exec` but through environmental variable and more limited
     159  * Use `grass.script.setup` package from GRASS GIS (requires boilerplate to add the packages on path first) 
     160  * Use the standalone `grass_session` package (new, see [https://grasswiki.osgeo.org/wiki/Working_with_GRASS_without_starting_it_explicitly#Python:_GRASS_GIS_7_with_an_external_library:_grass-session here])
     161  * Set up environmental variables and "RC file" yourself (the classic method).
     162 * None of these allows the user to skip the database setup phase. This leads to the need for constant reimplementing of setup, import and export steps in various software and environments including ''user scripts'' (in Bash, Python, R), QGIS Processing, gvSIG/SEXTANTE, uDig/JGrassTools, and all the web/server/cloud tools and applications which use GRASS GIS as a processing backend (e.g. PyWPS server).
     163 * GRASS GIS itself can make it easier for the callers (at least in most cases) by implementing an interface which would allow to use GRASS GIS modules without explicit dealing with GRASS GIS database.
     164 * The command line call using the proposed interface would look like these:
     165
     166{{{
     167grass run r.lake elevation=some/file.tiff water_level=10 lake=some/new/file.tiff coordinates=100,520
     168grass run r.slope.aspect elevation=file://.../elevation.tiff aspect=file://...aspect.tiff
     169grass run r.slope.aspect elevation=https://.../elevation.tiff.zip aspect=file://...aspect.tiff
     170}}}
     171
     172 * Basic execution phases:
     173  * The `grass` command would have to parse the command line, compare it with the module XML interface description, find the files which should be maps (either using `file://` and ideally anything else), potentially download and uncompress, and import (or link) them, and then call the actual command (GRASS module).
     174   * The input maps could be linked (external) rather than imported (except for the cases when projection differs) which should be faster than import.
     175   * Doing the work in GRASS rather than in the other software would allow GRASS to make the decision about the details, for example the data exchange (r.external vs r.import vs r.in.gdal - see [https://github.com/qgis/QGIS/pull/5426#issuecomment-345067457 comment from MarkusN for QGIS Processing issue] or [https://lists.osgeo.org/pipermail/grass-dev/2017-November/086598.html mailing list]).
     176  * GRASS Database would be created with an appropriate Location (projection based on input files or additional CLI input).
     177   * The GRASS GIS Database, Location and Mapset should be created on the fly and deleted afterwards (the `.grassrc` wouldn't be used).
     178  * Computational region would be set based on input file(s) or additional CLI input.
     179  * Module execution.
     180  * The output maps could be be also linked (e.g. r.external.out) with projection same as input which is should be faster then export.
     181   * Ideally export (as well as import) should work also with PostGIS and databases provided through GDAL/OGR.
     182 * Proposal should discuss and address how advanced things such raster algebra, multi-map inputs and outputs, temporal framework, cartography and visualization tools will work (or what are the limits).
     183 * Use should be able to always specify the details manually:
     184
     185{{{
     186grass run --mapset=/some/directory/grassdata/ncspm/practice1 r.lake elevation=some/file.tiff ...
     187grass run --region="s=55600 n=60500..." --mask=some/mask.tiff r.lake elevation=some/file.tiff ...
     188grass run --crs=EPSG:3358 --mask=some/mask.tiff r.lake elevation=some/file.tiff ...
     189grass run --use=some/file_a.tiff --get=some/file_b.tiff r.slope.aspect elevation=file_a aspect=file_b
     190}}}
     191
     192 * The system behind the interface will be inherently fragile, so it is necessary to write large amount of tests which would check different combinations of data types and projections.
     193 * All the underlying code is expected to be in Python, so the project should involve also creation of Python API on the way.
     194 * Bonus tasks:
     195  * Making this work for the GUI in the same way. It is expected that this would work for any `g.gui.*` modules too but implementing similar mechanism also for module dialogs is more work (but some basic implementation might be quite straightforward).
     196  * Making this connected to the standalone `grass_session` package.
     197  * Generalization of the API, so that it incorporates also the concept of remote sessions (see e.g. [https://github.com/wenzeslaus/g.remote g.remote on GitHub])
     198 * Current GRASS code involved:
     199  * source:grass/trunk/lib/python/script/setup.py (library function(s) for Location setup in Python)
     200  * source:grass/trunk/lib/init/grass.py (full GRASS GIS standard startup "script")
     201 * See also:
     202  * Tickets, PRs, commits:
     203   * #2424 PyGRASS does not work when GRASS is invoked from outside because it is not possible to change path to dynamic libraries in running process
     204   * #2511 Starting GRASS in mapset which is not owned by the user
     205   * #2579 Specify command to be executed as parameter of grass command (patch) and other suggestion for CLI, especially see the comment:15:ticket:2579 which summarizes the remaining issues after closing the ticket
     206   * #2639 grass command should read commands from stdin as an interpreter would do
     207   * #2678 GRASS starts even when Mapset is locked
     208   * #2679 Drop or fix setting of Location and Mapset using environmental variables
     209   * #2681 Remove legacy meaning of LOCATION variable
     210   * #2685 Add ignore lock flag to grass command
     211   * #3537 Add functionalities `--tmp-location` and `--no-clean`
     212   * r72790 Add `--tmp-location`
     213   * [https://github.com/OSGeo/grass/pull/313 PR #313] Add `--tmp-mapset` option
     214  * Documentation:
     215   * [https://grass.osgeo.org/grass74/manuals/grass_database.html GRASS GIS Database]
     216   * [https://grass.osgeo.org/grass70/manuals/libpython/script.html#module-script.setup grass.script.setup]
     217  * Mailing list and wikis:
     218   * [https://lists.osgeo.org/pipermail/grass-dev/2018-March/087764.html grass-dev New CLI GSoC Idea: Comments, Mentors, Students Needed] (whole thread)
     219   * [https://lists.osgeo.org/pipermail/grass-dev/2015-January/072979.html grass-dev QGIS Processing & GRASS (January 2015)]
     220   * [https://grasswiki.osgeo.org/wiki/Working_with_GRASS_without_starting_it_explicitly Working with GRASS without starting it explicitly]
     221   * wiki:Grass7/VectorLib/OGRInterface
     222   * wiki:Grass7/VectorLib/PostGISInterface
     223   * [https://lists.osgeo.org/pipermail/grass-dev/2015-February/073867.html On GSoC Proposal New easy-to-use...]
     224   * [https://lists.osgeo.org/pipermail/grass-dev/2015-March/074433.html GSOC project proposal]
     225   * Other projects (see also the ones linked in the text):
     226   * [https://github.com/qgis/QGIS/blob/0a1382a0be36d408aebd227fb0066f68c513e41e/python/plugins/processing/algs/grass7/Grass7Algorithm.py QGIS Processing Grass7Algorithm.py] source code
     227   * [https://github.com/moovida/jgrasstools/blob/530c87f26d220f3eeff9d2fb9d21abd8821c00c3/grass/src/main/java/org/jgrasstools/grass/utils/ModuleSupporter.java uDig's JGrasstools] source code
     228   * [https://sextante.googlecode.com/svn/trunk/soft/sextante_lib/sextante_gui/src/es/unex/sextante/gui/grass/ SEXTANTE grass] source code (broken link)
     229   * [https://github.com/geopython/PyWPS/blob/425f0eb160f60714a6705a24ba926e03690ab371/pywps/Grass.py PyWPS source code] and [https://pywps.wald.intevation.org/documentation/process.html PyWPS documentation] (broken link)
     230   * [https://code.google.com/p/wps-grass-bridge/source/browse/trunk/?r=97 wps-grass-bridge] source code (broken link)
     231  * Similar complex command line interfaces to learn from:
     232   * Git (a classic example of subcommand interface)
     233   * Docker (subcommand interface combined with running other commands inside a container)
     234   * !GeoGig (needs to get geospatial data in and out)
     235   * !ImageMagic
     236    * radical changes in CLI interface between versions [https://legacy.imagemagick.org/script/index.php 6] and [https://www.imagemagick.org/script/command-line-tools.php 7]
     237    * new CLI has a single `magick` command with many parameters
     238   * GMT
     239    * [http://gmt.soest.hawaii.edu/doc/5.3.2/GMT_Docs.html#new-features-in-gmt-5 radical changes in CLI interface between versions 4 and 5]
     240    * new CLI has a single `gmt` command and subcommands
     241 * Test and training tasks:
     242  * Extend `--exec` functionality:
     243   * Add `--clean` (current default) and `--no-clean` which say if `--exec` should clean the `.tmp` directory in the Mapset (for parallel execution). (See also #3537.)
     244   * Add `--lock` (current default) and `--no-lock` which say if `--exec` should lock the Mapset (for parallel execution). See also #2685 and the `-f` flag.
     245   * Add `--region` to set a temporary computational region for the execution, e.g. `--region="raster=raster_name"`
     246   * Add `--import-raster=some/file.tiff` which imports (r.in.gdal or r.import) a raster file (same for vector).
     247   * Add `--link-raster=some/file.tiff` which links (r.external) a raster file (same for vector).
     248   * Add `--export-raster=some/file.tiff` which exports (e.g. r.out.gdal) a raster file (same for vector).
     249   * Add `--link-output-raster=some/file.tiff` which creates (r.external.out) a new (output) raster file (same for vector).
     250  * Add features to `grass` executable interface:
     251   * Make it possible to associate `*.gxw` files with `grass` executable (#1204) or at least add `--gui-workspace` or preferably just recognize it in the command line (distinguish it from database/location/mapset).
     252  * Solve one of the tickets linked above.
     253
     254== Tips for students ==
     255
     256 * If you have your own ideas we encourage you to propose them. Explain them on the [https://lists.osgeo.org/listinfo/grass-dev grass-dev mailing list].
     257 * If you like some idea here or from previous yeas, write about it on [https://lists.osgeo.org/listinfo/grass-dev grass-dev mailing list] and any ideas of your own which could improve it.
     258 * Follow some good practices in your ideas and proposals:
     259  * Stress why the project would be useful.
     260  * Show that you know how you will proceed. That is, make sure that you can demonstrate that the proposal is feasible in the given time frame.
     261  * Be specific in the implementation (or at least as specific as you can).
     262  * Explain what the final product will look like and how it will work. Perhaps you can add some drawings or mock-ups. (here in a wiki page)
     263  * Explain how the idea relates to existing GRASS GIS functions, features, and needs.
     264  * Do not include steps such as "install GRASS", "compile GRASS libraries (on my machine)", "read about the API". You should do this before applying to GSoC.
     265 * Compile GRASS GIS 7 (trunk) from source and prepare environment for development:
     266  * See links appropriate for you at [https://grass.osgeo.org/development/how-to-start/].
     267  * If you get stuck with the setup, feel free to consult the [https://lists.osgeo.org/listinfo/grass-user grass-user mailing list].
     268  * Familiarize yourself with wiki:Submitting rules.
     269 * Prove your worth by being active on the GRASS mailing lists ([https://lists.osgeo.org/listinfo/grass-user grass-user], [https://lists.osgeo.org/listinfo/grass-dev grass-dev]), fix some [https://trac.osgeo.org/grass/report bugs], and/or implement some (smaller) features, or write some (simpler) GRASS module, and post it to mailing list. There's no better way to demonstrate your willingness and abilities. You should start even before you apply to GSoC.
     270 * Also note that fixing existing bugs and/or implementing enhancements will be a part of student evaluation.
     271
     272 * Every year GRASS GIS hopes to participate and participates in GSoC as part of the [https://www.osgeo.org/ OSGeo Foundation]'s GSoC program umbrella. See the official OSGeo template for application details and other important information at the [https://wiki.osgeo.org/wiki/Google_Summer_of_Code_2019 OSGeo GSoc Ideas page].