For reference, this is my draft outline of the video series that I had in my head (I’m going to try to make this a Wiki so that others can edit it, if they like):
1. Overview of series
- iNat is primarily for connecting people to nature and creating a community of folks interested in nature, but data is a nice byproduct.
- Show some interesting / meaningful examples of how people have used the data from iNaturalist
- Talk about the goals of the series
- Aim for breadth rather than depth. (It’s simply not possible to cover every way to interact with data.)
- When talking about tools, focus on ones that are easy to use and/or provide others easy access to things made in those platforms
- (Overview of the rest of the series)
2. Getting the most out of the web UI
- For a lot of people, the website provides everything they need to get all the data they will ever need.
- Goal 1: Share tips for using the screens better (with emphasis on Explore screen, whose basic functions are covered well in https://forum.inaturalist.org/t/the-inaturalist-explore-page-an-introduction/12966)
- Pin types and colors
- Notes on obscured and private data
- What kind of data is excluded by default from the Explore screen? (casual & spam, plus non-mappable in the maps)
- Location vs. place filtering, filtering by bounding box, filtering by radius
- Enhanced filter interface in the Identify screen
- Filtering using parameters in the URL (https://forum.inaturalist.org/t/how-to-use-inaturalists-search-urls-wiki/63, https://forum.inaturalist.org/t/how-to-use-inaturalists-search-urls-wiki-part-2/18792), including:
- exclusion filters
- filter by annotations
- filter by observation fields
- Goal 2: Provide a broad overview of other data-related stuff available in the system
- Taxon screen stuff
- seasonality, phenology, and related graphs
- taxonomy
- enhanced image viewer with filters
- enhanced map (which can be viewed in a standalone version - ex. https://www.inaturalist.org/taxa/map?taxa=3,4#2/0/0)
- Heat map (https://www.inaturalist.org/observations/map)
- Experimental Compare Tool (https://www.inaturalist.org/observations/compare)
- Life list, plus old lists & filtering by lists
- Project stats
- Year in Review
- Taxon screen stuff
3. Basic ways to download iNaturalist data
- Sometimes the screens just don’t provide data in the format that you need. But the system also provides some ways to download data so that you can use it in your own creations.
- Observation CSV download
- Show how to use
- Considerations:
- up to 200,000 observations per request
- handles a wide variety of filter input parameters and output field options, but not always easy to replicate exact setups (if changing these)
- can get unobscured coordinates (if you have the right privileges)
- observation field output (need to have used the observation field before it becomes available)
- does not handle one-to-many data relationships well (ex. multiple photos per observation)
- project page variant
- List taxon downloads
- Place KML downloads
4. Quick detour: Getting data from GBIF
- A lot of iNaturalist data is pushed to GBIF, which has some functionality that iNaturalist doesn’t.
- What gets pushed to GBIF (research grade + properly licensed), and how often is it updated?
- Extra features of GBIF
- Has other (non-iNaturalist) data, too
- Has additional ways to filter data (ex. polygon geographic filtering)
- Can export more observation-level data
- Can get a DOI (Digital Object Identifier) for citations
- More map visualizations (API)
5. Let’s Demystify the API
- Generally what is an API?
- Quick definition
- For iNaturalist, the most important thing is that it standardizes the way the website, Android app, and iOS app interface with stuff on the back end.
- Primarily it’s there for app development, but it can be used to get data. (Much of what apps do is just to display data.)
- Pros and cons of API vs CSV downloads
- Introduce some terms (ex. request, response, endpoint, throttling), but don’t get too technical
- iNat has 3 APIs - an old Ruby-based API (mostly deprecated), the current (v1) Node-based API, and a (v2) Node-based API under development
- Generally, we will talk about the (v1) Node-based API because it’s the current one
- What kind of data is available in the iNat API?
- Start by showing https://api.inaturalist.org/v1/docs/
- lists most endpoints (excludes things like computer vision)
- lists most parameters for each endpoint
- provides an interface for constructing a request, making a request, and viewing the response
- Since we’re generally concerned about getting data, we’re mostly interested in GET endpoints
- Most of the GET endpoints can be accessed anonymously (and should be accessed anonymously)
- (The GET endpoints that might provide different results if authenticated are Observation endpoints that can provide private coordinates.)
- Generally, these endpoints will return data in the form of a json file or an image file (map tiles). (The deprecated endpoint also provided a few other output file formats.)
- Use https://api.inaturalist.org/v1/docs/ to make some API requests and view the results
- Observation search query (returns json)
- explain the general structure of most of these json files (includes total_results, results in various formats depending on endpoint, and usually per_page and page)
- talk about API request limits
- rate (around 1 request per second, except for autocomplete endpoints)
- records (usually around 200 per page, up to top 10000 records for a given set of parameters)
- Observation map query (returns image file)
- (show the special case of UTFGrids?)
- Show how to make an authenticated request on the Observation Search endpoint via https://api.inaturalist.org/v1/docs/
- Observation search query (returns json)
- Go over to the old API docs just to talk about it, and show an example of how it can output stuff to, say, CSV.
- Start by showing https://api.inaturalist.org/v1/docs/
- Point to the Recommended Practices doc (https://www.inaturalist.org/pages/api+recommended+practices) for more guidance.
- The rest of the series will cover how to use specific tools / platforms to access the API.
6. Getting json data from the API into Excel using Power Query
- Excel is one of the most popular and mature tools for working with data
- Power Query (part of Office 365 and available in versions 2010 and up) provides a quick way to import data json data.
- Go through the process
- Construct an API request
- Show how to format the data into a table
- Show how to refresh the data
- Show how to change the query
- Make something interesting with the data (or show something interesting that has been made)
- Usage notes:
- this is good for aggregated data (ex. histogram data) and small sets of records that don’t span multiple pages of requests (ex. up to 200 observations)
- it’s possible to have Excel pull in multiple pages, but this is usually better accomplished in other tools. (So we will not cover this here.)
7. Getting json data from the API into data.world
- data.world is a promising (online) platform for sharing data and connecting data from various sources.
- (A free account provides a limited number of data sets and projects, and offers access to a broad catalog of community-created data)
- Go through the process
- Construct an API request
- Show how to format the data into a table file
- Show how to refresh the data (or set for automatic refresh)
- Show how to change the query
- Make something interesting with the data (or show something interesting that has been made)
- Usage notes:
- this is good for aggregated data (ex. histogram data) and small sets of records that don’t span multiple pages of requests (ex. up to 200 observations)
- data can be shared with other data.world users
8. Getting map tiles from the API into ArcGIS Online (AGOL)
- ArcGIS Online is the cloud variant of the popular ArcGIS platform (think maps).
- AGOL can be used in a limited way even without an account, but a free Public Account allows you to save and share your creations with the public, provides greater access to a huge catalog of data/layers available in AGOL, and offers limited access to some features available only in the online platform (ex. creating Story Maps).
- First, quick detour: Provide a basic overview of how tiled maps work
- why deliver data as tiles?
- introduce some basic concepts like zoom level, x, y
- Give a quick overview of the tiles that iNat offers
- Observation tiles (pins, density grid, heatmap, circles)
- Place tiles
- Taxon range tiles
- Taxon place tiles
- Note: observation tiles and taxon range tiles have color options
- Go through the process of getting data from iNaturalist
- Construct an API request (AGOL uses {level}/{col}/{row})
- Show how to add data to map
- Show how to limit layers to certain zoom levels
- Make something interesting with the data (or show something interesting that has been made)
- Usage notes:
- Data automatically refreshes
- Observation tiles are not interactive by themselves. Making them interactive requires some additional programming using UTFGrids (which will not be covered here).
- AGOL can also map out data given GPS coordinates or WKT points, but that will not be covered here, since that’s relatively easy to figure out.
9. Getting map tiles from API into QGIS
- QGIS is a free and powerful GIS application with lots of community-created extensions
- Show how to add some basemaps
- Go through the process of adding iNat data
- Construct an API request (QGIS uses {z}/{x}/{y})
- Show how to add data to map
- Show how to limit layers to certain zoom levels
- Show how to change the change XYZ tileset setup
- Make something interesting with the data (or show something interesting that has been made)
- Go through and add some data from GBIF while we’re at it.
- Construct an API request, etc.
- Usage notes:
- Data automatically refreshes
- Observation tiles are not interactive by themselves. Making them interactive requires some additional programming using UTFGrids (which will not be covered here).
- QGIS can also map out data given GPS coordinates, but that will not be covered here, since that’s relatively easy to figure out.
10. Getting json data from API for use with R via RStudio (desktop, probably)
- R is a powerful platform for data analysis and programming, used by lots of data scientists, with lots of packages for doing all sorts of things
- Talk about different ways to fetch data
- Mention rinaturalist (which is based on the deprecated API) and hanly’s iNatTools package (which is based on the v1 API)
- Go through the process of fetching iNat data
- Construct an API request
- Show how to put the data into a data frame
- Show how to construct a loop to get multiple pages of information
- Make something interesting with the data (or show something interesting that has been made). possible examples:
11. Getting json data from API for use with Python (via TBD, probably Jupyter)
- Python is one of the most popular programming languages in the world
- Go through the process of fetching iNat data
- Construct a basic API request
- Talk about PyiNaturalist (https://github.com/niconoe/pyinaturalist, which can hit both Ruby and Node APIs)
- Show how to get data (probably via PyiNaturalist, to simplify things), and view the contents of the results
- Make something interesting with the data (or show something interesting that has been made). Possible examples:
12. Getting json data from API into Observable (sort of Javascript)
- Observable is an interesting online notebook-style platform for coding(?) that is focused on modularity and sharability (is that a word?)
- Go through the process of fetching iNat data
- Construct a basic API request
- Show how to view the results
- Construct a loop to get multiple pages of data
- Make something interesting with the data (or show something interesting that has been made). Possible examples:
- Usage notes:
- Observable generally updates instantly with each interaction. So must be careful about setting up input fields for typing in API request fields (ex. https://observablehq.com/@kueda/inat-observations-histogram-to-csv), since a request could be made with each keystroke.
- Discuss other ways to work with Javascript (including a plug for inaturalistjs)