Geo-Computation and Environmental Analysis 5-Day Workshop
Yale University, New Haven, USA
May 13-17th, 2019
The open source spatiotemporal data analyses and processing workshop is an immersion 5-day experience opening new horizons on the use of the vast potentials of the Linux environment and the command line approach to process geographical data. We will guide newbies who have never used a command line terminal to a stage which will allow them to understand and use very advanced open source data processing routines. Our focus is to enhance the approach of self-learning allowing participants to keep on progressing and updating their skills in a continuously evolving technological environment.
Mr. Jacob Bukoski ( University of California, Berkeley)
The workshop is aimed at students who are currently at the master or doctoral level, as well as researchers with a common interest in spatiotemporal data analysis and modelling. Nonetheless, we accept undergraduate students as well. Participants should have basic computer skills and a strong desire to learn command line tools to process data. We expect students to have a special interest on geographical data analyses, previous experience in Geographic Information Systems would be helpful. Students need to bring their own laptops with a minimum of 4GB RAM and 30GB free disk space.
The workshop provides students with the opportunity to develop key skills required for advanced spatial data processing. Throughout the training students will focus on developing independent learning skills which will be fundamental for a continuous learning process of advanced data processing. This is a progressing journey of development with the availability of more complex data and the ongoing technological revolution. Within the course many different, complementary and sometimes overlapping tools will be presented to provide an overview of the existing open source software available for spatial data processing. We will discuss their strengths, weaknesses and specificity for different data processing objectives (e.g.modelling, data filtering, query, GIS analyses, graphics or reporting) and data types. In particular, we will guide students to practice the use of different types of software and tools with the objective to assist in gaining a steep learning curve, which is generally experienced while using the new approach of analyzing data within a programming command line environment. Broadly, we focus our training on helping students to develop independent learning skills to find online help, solutions and strategies to fix bugs and independently progress with complex data processing problems.
The academic program is divided into the following areas of study and interactions:
Lectures: (15 to 30 minutes each) Students will take part in a series of lectures introducing basic functions of tools, theoretical aspects and background information, which is needed for a better understanding of the deeper concepts to be successively applied in data processing.
Hands on Tutorials: Students will be guided during hands on sessions where trainers will perform data analyses on real case study datasets, while the students fill follow the example procedure using their laptops. During tutorials sessions students are supported by two trainers, one for the demonstrations and one to supervise the students' work as well as helping with individual guidance on coding.
Hands on Exercises: In addition to tutorials and lectures, students are encouraged to take up their own independent study during the exercise sessions. Specific tasks will be set allowing to reinforce the newly learned data processing capacity presented in lectures and practically learned during the tutorial sessions. Such exercise sessions equip students with the confidence and skills to become independent learners and effectively engaged with the demands of advanced spatial-data processing.
Depending on the number of participants and their previous knowledge in programming, the more or the less topics can be addressed in accordance to the students' needs. The exercises and examples will be cross-disciplinary: forestry, landscape planning, predictive modelling and species distribution, mapping, nature conservation, computational social science and other spatially related fields of studies. Nevertheless, these case studies are template procedures and could be applied to any thematic applications and disciplines.
Round table discussions: these sessions are mainly focused on exchanging experiences, needs and point of views. We aim at clarifying specific student’s needs and challenges, focus on how to help and how to find solutions while problem solving.
Our workshop will enable students to further develop and enhance their spatiotemporal data processing skills. Most importantly, it will allow them to start using professionally a fully functional open source operating system with software. With continuous practice during the week students will get more and more familiar with the command line and will focus on developing specific areas, including:
Time table: (7hr teaching/day)
Syllabus and Course Schedule
(some hours/topics can change in accordance to the needs of the participants)
Session 1. Getting started: Knowing each other and LINUX OS (GA) (1.30 - 2.00 hours)
This session introduces the overall course program and Linux operating system. We also learn how to install and use a virtual environment operating system.
Session 2. Jump start LINUX Bash programming (GA) (3.00-4.00 hours)
During this session we explore and practice the basics of BASH terminal command line. The acquired skills will be used in all following sections.
Session 3: AWK Programming language (If we have time) (GA) (0.30 -1.00 hours)
This session is fundamental for data filtering and preparation, text files manipulation, descriptive statistics and basic mathematical operation on large files. Students will access, query, understanding and cleaning up data, perform data filtering using bash command line. We use AWK which is an extremely versatile and powerful programming language for working on text files, performing data extraction and reporting or to squeeze data before importing them into R or other software types.
Session Recap: Review the main command of Linux OS
Getting started with Python (JB)
During this session we explore and practice the basics of PYTHON language. We will describe the fundamental structure of python objects and how to build functions, modules and classes. The acquired skills will be used in all following sections.
Session 6. Basic concept of GIS and Remote Sensing (GA)
Session 6. Exploring and understanding geographical data: introduction to GDAL/OGR libraries (GA)
This section introduces data manipulation for geospatial data processing on the command line using GDAL and OGR libraries.
This section the course participants can bring their data and start to manipulate the and analysis using the tools up to know presented. You can decide to work in group or by yourself. We will assist you and suggest the best tools available.
Session 9 - Command line GIS - Getting started with GRASS and Qgis (GA)
This session will introduce the use of GRASS geographic information system in its command line interface for spatial-data processing, and the use of QGIS for map visualization and overlay tool. We do not expect any previous knowledge of GRASS or Qgis, but will use basic BASH and GDAL command line skills acquired in the previous days. This session is interesting for people that deal with general GIS analysis, hydrological modelling, DEM, vector/ raster data integration etc. This section is fundamental for the topic of tomorrow.
Session 8. Using Python for GIS and Remote Sensing operations - (JB)
This section focuses on the use of python for GIS and Remote Sensing Operations. Python can be used as an alternative language to BASH to call GDAL/OGR or PKTOOLS command line tools but can be also used as integrate the GDAL/OGR API in your process.
Session 9. Working on student’s personal data
CONCLUSION – Focus on the student projects needs and how to get going with the use of free and open source tools for advanced spatial data processing.
Round table, question and answer session on specific data processing needs and how to follow up the summer school using open source softwares as daily working toolbox.
Parallel session 10a (ADVANCE): Batch processing data using GRASS (GA) TBD
This parallel section assumes good understanding and discrete control of Bash command line and full knowledge of GRASS location and mapset. It is mainly indicate for people that already move in the direction of large data processing and are willing to explore more on batch job processing and multi-core data manipulation for Geo-Computation.
Parallel session 10b (INTERMEDIATE): GIS and RS with R (BP) TBD
This section shows the use of R for GIS and RS analysis, mainly using raster packages. A brief talk is presented followed by a small study case.
Parallel session 10c (ADVANCE): Parallel processing in R (SW) TBD
In this section, the use of R for parallel statistical computation will be introduced. A lecture will introduce the concept of parallelization in R presenting the different R library available. This section assumes a basic knowledge of R.