<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:Wingdings;
        panose-1:5 0 0 0 0 0 0 0 0 0;}
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
span.EmailStyle19
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:70.85pt 70.85pt 70.85pt 70.85pt;}
div.WordSection1
        {page:WordSection1;}
/* List Definitions */
@list l0
        {mso-list-id:1210723608;
        mso-list-template-ids:1143246660;}
@list l0:level1
        {mso-level-number-format:bullet;
        mso-level-text:\F0B7;
        mso-level-tab-stop:36.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Symbol;}
@list l0:level2
        {mso-level-number-format:bullet;
        mso-level-text:o;
        mso-level-tab-stop:72.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:"Courier New";
        mso-bidi-font-family:"Times New Roman";}
@list l0:level3
        {mso-level-number-format:bullet;
        mso-level-text:\F0A7;
        mso-level-tab-stop:108.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level4
        {mso-level-number-format:bullet;
        mso-level-text:\F0A7;
        mso-level-tab-stop:144.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level5
        {mso-level-number-format:bullet;
        mso-level-text:\F0A7;
        mso-level-tab-stop:180.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level6
        {mso-level-number-format:bullet;
        mso-level-text:\F0A7;
        mso-level-tab-stop:216.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level7
        {mso-level-number-format:bullet;
        mso-level-text:\F0A7;
        mso-level-tab-stop:252.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level8
        {mso-level-number-format:bullet;
        mso-level-text:\F0A7;
        mso-level-tab-stop:288.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
@list l0:level9
        {mso-level-number-format:bullet;
        mso-level-text:\F0A7;
        mso-level-tab-stop:324.0pt;
        mso-level-number-position:left;
        text-indent:-18.0pt;
        mso-ansi-font-size:10.0pt;
        font-family:Wingdings;}
ol
        {margin-bottom:0cm;}
ul
        {margin-bottom:0cm;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="NO-BOK" link="blue" vlink="purple" style="word-wrap:break-word">
<div class="WordSection1">
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US">Yes, great work indeed!<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US">Also kudos to those who initiated the mini-grant concept! It is for sure a very good and very fruitful investment of resources. Speaking for myself, it really motivates to donate to
 the project when one sees such great outcome as from Linda and Caitlin!<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US">Cheers<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US">Stefan<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="mso-fareast-language:EN-US"><o:p> </o:p></span></p>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0cm 0cm 0cm">
<p class="MsoNormal"><b><span lang="EN-US">From:</span></b><span lang="EN-US"> grass-psc <grass-psc-bounces@lists.osgeo.org>
<b>On Behalf Of </b>Veronica Andreo<br>
<b>Sent:</b> tirsdag 19. april 2022 22:07<br>
<b>To:</b> GRASS-PSC <grass-psc@lists.osgeo.org><br>
<b>Subject:</b> [GRASS-PSC] [Motion] Approve Caitlin's student grant final report and issue the second payment<o:p></o:p></span></p>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div>
<p class="MsoNormal">Dear PSC,<o:p></o:p></p>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Caitlin has just completed her project for the student grant and submitted the final report (I FWD it here in case you missed it).<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I hereby propose to approve her final report and issue the second half of the payment. Big thanks to Caitlin and her mentors for your work and commitment! Thanks as well to those testing and providing feedback along the process! Great work
 Caitlin!! Congratulations!<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">I start with my +1 !!<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<div>
<p class="MsoNormal">Vero<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"><o:p> </o:p></p>
<div>
<div>
<p class="MsoNormal">---------- Forwarded message ---------<br>
De: <strong><span style="font-family:"Calibri",sans-serif">Caitlin Haedrich</span></strong> <<a href="mailto:caitlin.haedrich@gmail.com" target="_blank">caitlin.haedrich@gmail.com</a>><br>
Date: lun., 18 abr. 2022 19:25<br>
Subject: [GRASS-dev] grass.jupyter Mini Project Final Report<br>
To: <<a href="mailto:grass-dev@lists.osgeo.org" target="_blank">grass-dev@lists.osgeo.org</a>>, <<a href="mailto:grass-user@lists.osgeo.org" target="_blank">grass-user@lists.osgeo.org</a>><o:p></o:p></p>
</div>
<p class="MsoNormal" style="margin-bottom:12.0pt"><o:p> </o:p></p>
<div>
<p class="MsoNormal">Hi all,<br>
<br>
Last week, we wrapped a final push on grass.jupyter and are excited for its official release with GRASS 8.2. Here's my final report along with a summary of grass.jupyter changes introduced as part of the project. Thank you all for your support, feedback and
 testing over the past few months!<br>
<br>
<b>The state of the art BEFORE the start of the Mini Project:</b><br>
During GSoC 2021, we created “grass.jupyter”, a package that improves the integration of GRASS GIS and Jupyter with a set of functions for displaying GRASS data in Jupyter Notebooks. In its previous state, “grass.jupyter” allows users to create static visuals
 and simple interactive maps. However, several additional features are needed to allow Jupyter users to fully and easily access the power GRASS, including space-time dataset visualization and more options for interactive mapping.<br>
<br>
<b>Project Goals</b>: <br>
In preparation for the stable release of grass.jupyter with GRASS 8.2, this project had three main goals: (1) create space time dataset visualizations for use in Jupyter Notebooks, (2) improve the integration of GRASS with folium (leaflet library for Python)
 and (3) write a function for displaying vector attributes in nicely-formatted tables (using Pandas or Geopandas). Along the way, we also wanted to finalize the naming of grass.jupyter classes and create documentation (thank you Vaclav Petras).<br>
<br>
<b>The state of the art AFTER the Mini Project:</b><br>
1. New TimeSeriesMap class that creates ipywidget time sliders of space time datasets (see attached timeseriesmap.png) and a notebook documenting it's usage [1]<br>
2. Improved GRASS-folium integration allowing rasters and vectors to be added to existing folium maps (see attached grass-folium.png) and updated notebook demonstrating its usage [2]<br>
3. Updated class names:<o:p></o:p></p>
<ul type="disc">
<li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
GrassRenderer -> Map<o:p></o:p></li><li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
Grass3dRenderer -> Map3D<o:p></o:p></li><li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
InteractiveMap<o:p></o:p></li><li class="MsoNormal" style="mso-margin-top-alt:auto;mso-margin-bottom-alt:auto;mso-list:l0 level1 lfo1">
TimeSeries -> TimeSeriesMap<o:p></o:p></li></ul>
<p class="MsoNormal">4. Thanks to Vaclav Petras, we also have a manual page for grass.jupyter [3]<br>
5. I didn't end up working to integrate GRASS and Pandas. It seems that it is quite straightforward to display vector attributes in nicely-formatted Pandas tables. For example:<o:p></o:p></p>
<div>
<blockquote style="margin-left:30.0pt;margin-right:0cm">
<p class="MsoNormal">>>> import pandas as pd<o:p></o:p></p>
<p class="MsoNormal">>>> import sqlite3<br>
>>> sql_path = gs.read_command("db.databases", driver="sqlite").replace('\n', '')<br>
>>> con = sqlite3.connect(sql_path)<br>
>>> sql_stat="SELECT * FROM field"<br>
>>> df = pd.read_sql_query(sql_stat, con)<o:p></o:p></p>
<p class="MsoNormal">>>> con.close()<br>
>>> df<o:p></o:p></p>
</blockquote>
<p class="MsoNormal">There are other outputs that would be nice to display in nice Pandas tables, like text output from r.univar, r.stats, or t.vect.list. However, this is difficult since there is no standard output that is easily parse-able to pandas. I think
 the best way would be to create a standard json or csv output for all modules that return text. Then, it would be simple to take any module output and convert to a nice-looking Pandas table.<br>
<br>
<b>Next Steps:</b><br>
1. Bug: InteractiveMap does not honor use_region=True for vectors.<br>
2. Bug: InteractiveMap for Jupyter does not handle not existing data properly (<a href="https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2FOSGeo%2Fgrass%2Fissues%2F2302&data=05%7C01%7Cstefan.blumentrath%40nina.no%7C1d6e6450cf894890572208da224a0d9d%7C6cef373021314901831055b3abf02c73%7C0%7C0%7C637859999631379871%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=BOvuume3H23ptQ8orKnhuptwIJMQg%2FqhBNWGYkx5kLo%3D&reserved=0" target="_blank">https://github.com/OSGeo/grass/issues/2302</a>)<br>
3. InteractiveMap: add legend options for rasters, support simpleCRS for faster rendering, ToolTip integration for vector attributes<br>
4. Continue Pandas integration by adding standard json or csv output to modules that return text<br>
5. ... And many others! I think there's still lots of ways we can improve and expand the integration of GRASS and Jupyter. Ideas welcome.<br>
<br>
You can find an archive of all my weekly reports at [4] and follow next steps for grass.jupyter on our project page on GitHub [5]. Thank you again to Vaclav Petras and Anna Petrasova for their guidance and contributions to grass.jupyter. And, another thank
 you to Vero Andreo, Stefan Blumentrath and Markus Neteler for their feedback and testing!<br>
<br>
Best,<br>
Caitlin<br>
<br>
[1] <a href="https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fmybinder.org%2Fv2%2Fgh%2FOSGeo%2Fgrass%2Fmain%3Furlpath%3Dlab%252Ftree%252Fdoc%252Fnotebooks%252Ftemporal.ipynb&data=05%7C01%7Cstefan.blumentrath%40nina.no%7C1d6e6450cf894890572208da224a0d9d%7C6cef373021314901831055b3abf02c73%7C0%7C0%7C637859999631379871%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=xoIEUwwuiGAAxxm1yLnooXMqImHY%2BgYgyCCFtAA6V5c%3D&reserved=0" target="_blank">
https://mybinder.org/v2/gh/OSGeo/grass/main?urlpath=lab%2Ftree%2Fdoc%2Fnotebooks%2Ftemporal.ipynb</a><br>
[2] <a href="https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fmybinder.org%2Fv2%2Fgh%2FOSGeo%2Fgrass%2Fmain%3Furlpath%3Dlab%252Ftree%252Fdoc%252Fnotebooks%252Fgrass_jupyter.ipynb&data=05%7C01%7Cstefan.blumentrath%40nina.no%7C1d6e6450cf894890572208da224a0d9d%7C6cef373021314901831055b3abf02c73%7C0%7C0%7C637859999631379871%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=2tGXMGTj5lXgLZDdWfdJ7PyBrZm9MbMB49wUFOYjeKs%3D&reserved=0" target="_blank">
https://mybinder.org/v2/gh/OSGeo/grass/main?urlpath=lab%2Ftree%2Fdoc%2Fnotebooks%2Fgrass_jupyter.ipynb</a><br>
[3] <a href="https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgrass.osgeo.org%2Fgrass81%2Fmanuals%2Flibpython%2Fgrass.jupyter.html&data=05%7C01%7Cstefan.blumentrath%40nina.no%7C1d6e6450cf894890572208da224a0d9d%7C6cef373021314901831055b3abf02c73%7C0%7C0%7C637859999631379871%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=q2tfFUqGYSj5Htv2MMsbu%2B2zjEOTFpAGAtIRonLClVA%3D&reserved=0" target="_blank">
https://grass.osgeo.org/grass81/manuals/libpython/grass.jupyter.html</a><br>
[4] <a href="https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Ftrac.osgeo.org%2Fgrass%2Fwiki%2FGSoC%2F2021%2FJupyterAndGRASS%2FMiniGrant2022&data=05%7C01%7Cstefan.blumentrath%40nina.no%7C1d6e6450cf894890572208da224a0d9d%7C6cef373021314901831055b3abf02c73%7C0%7C0%7C637859999631379871%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=KUvSF3OicSOBsbOw4VWnTzEDqlFDExbH5OhndpWE04I%3D&reserved=0" target="_blank">
https://trac.osgeo.org/grass/wiki/GSoC/2021/JupyterAndGRASS/MiniGrant2022</a><br>
[5] <a href="https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fgithub.com%2FOSGeo%2Fgrass%2Fprojects%2F7&data=05%7C01%7Cstefan.blumentrath%40nina.no%7C1d6e6450cf894890572208da224a0d9d%7C6cef373021314901831055b3abf02c73%7C0%7C0%7C637859999631379871%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=RgwtNmsiBK%2FWDCOyo3BPuQGUeBtOnAKn9jcV5RufVQU%3D&reserved=0" target="_blank">
https://github.com/OSGeo/grass/projects/7</a><o:p></o:p></p>
</div>
</div>
<p class="MsoNormal">_______________________________________________<br>
grass-dev mailing list<br>
<a href="mailto:grass-dev@lists.osgeo.org" target="_blank">grass-dev@lists.osgeo.org</a><br>
<a href="https://eur01.safelinks.protection.outlook.com/?url=https%3A%2F%2Flists.osgeo.org%2Fmailman%2Flistinfo%2Fgrass-dev&data=05%7C01%7Cstefan.blumentrath%40nina.no%7C1d6e6450cf894890572208da224a0d9d%7C6cef373021314901831055b3abf02c73%7C0%7C0%7C637859999631379871%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjAwMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C%7C&sdata=IOxrtKnf1rxScAA9Wzeim8Scnmrpq4IB865PUBfhhWY%3D&reserved=0" target="_blank">https://lists.osgeo.org/mailman/listinfo/grass-dev</a><o:p></o:p></p>
</div>
</div>
</div>
</body>
</html>