-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathREADME.Rmd
108 lines (81 loc) · 5.61 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
---
output:
html_document:
keep_md: yes
---
```{r, echo=FALSE, message=FALSE}
load('key.rdata')
knitr::opts_chunk$set(cache = TRUE)
```
<!-- badges: start -->
[![Travis build status](https://travis-ci.org/BiologicalRecordsCentre/plantnet.svg?branch=master)](https://travis-ci.org/BiologicalRecordsCentre/plantnet)
[![Codecov test coverage](https://codecov.io/gh/BiologicalRecordsCentre/plantnet/branch/master/graph/badge.svg)](https://codecov.io/gh/BiologicalRecordsCentre/plantnet?branch=master)
[![AppVeyor build status](https://ci.appveyor.com/api/projects/status/github/BiologicalRecordsCentre/plantnet?branch=master&svg=true)](https://ci.appveyor.com/project/BiologicalRecordsCentre/plantnet)
<!-- badges: end -->
# PlantNet
### Developed by Tom August
last built `r Sys.Date()`
The R-package interfaces with the PlantNet image classification API. This API is designed to receive images and return species classifications. You can find out more about the PlantNet project here: https://plantnet.org. To use the API you need to have registered an account and generated an API key. All this can be done here: https://my.plantnet.org/.
## Install the package
To install the development version of this package from Github use this code.
```{r install, eval = FALSE}
# Install using the devtools package
devtools::install_github(repo = 'BiologicalRecordsCentre/plantnet')
```
```{r library, message=FALSE}
library(plantnet)
```
## Using the package to classify images
The images that you want to classify need to have URLs. If the images you have are not online you will need to put them online and then copy all of the URLs. The other information you need is your API key. You can create this after registering here: https://my.plantnet.org/.
### Single image
With these we can do a single image classification like this. Here we use this photo of a lavender
<center><img style="max-width: 450px" src="https://upload.wikimedia.org/wikipedia/commons/thumb/6/60/Single_lavendar_flower02.jpg/800px-Single_lavendar_flower02.jpg"></center>
<br>
```{r key, eval=FALSE}
# Get your key from https://my.plantnet.org/
key <- "YOUR_SUPER_SECRET_KEY"
```
```{r one_image1}
# Get the URL for your image
imageURL <- 'https://upload.wikimedia.org/wikipedia/commons/thumb/6/60/Single_lavendar_flower02.jpg/800px-Single_lavendar_flower02.jpg'
```
```{r one_image2}
classifications <- identify(key, imageURL)
classifications
```
You can see in the the table returned there are three columns returned. The first gives you a score, this is the likelihood that the species in this row is the correct classification for the image you provided. As you can see in this instance there is not much between the top two species so we could not be confident which species it is. The second column gives the Latin names as binomials, and the final column gives the most commonly used common name for the species.
If you want more information, such as a list of all of the common names for each classification, or the full Latin name including authors, you can access all of this information by using `simplify = FALSE`.
```{r simpOff}
classifications <- identify(key, imageURL, simplify = FALSE)
str(classifications,1)
```
The top elements give some information about the call we made to the API, but the results contains what we are usually after. Results has one entry for each species classification, or each row in the table we saw above. Let's look at one.
```{r results}
classifications$results[[1]]
```
Here we have information on the Latin name, authors, and at the end, a list of the common names.
### Multiple images
You can get a better identification if you provide more than one image of the plant, and of multiple organs of the plant. The organs that PlantNet considers are: leaf, flower, fruit, bark. You can also take images classed as habit (the overall form of the plant), or other, but you can only have an image labelled as one of these if you also have an image labelled as one of the primary organs (i.e. leaf, flower, fruit, bark).
In this example we are going to use three images of Quercus robur from the Encyclopedia of Life.
<center><img style="max-width: 450px" src="https://content.eol.org/data/media/55/2c/a8/509.1003460.jpg"></center>
<br>
<center><img style="max-width: 450px" src="https://content.eol.org/data/media/89/88/4c/549.BI-image-16054.jpg"></center>
<br>
<center><img style="max-width: 450px" src="https://content.eol.org/data/media/8a/77/9b/549.BI-image-76488.jpg"></center>
<br>
```{r multi1}
# We can search using up to five images
# Here are three picture of Quercus robur
imageURL1 <- 'https://content.eol.org/data/media/55/2c/a8/509.1003460.jpg'
imageURL2 <- 'https://content.eol.org/data/media/89/88/4c/549.BI-image-16054.jpg'
imageURL3 <- 'https://content.eol.org/data/media/8a/77/9b/549.BI-image-76488.jpg'
identify(key, imageURL = c(imageURL1, imageURL2, imageURL3))
```
In this case all three images have been used to arrive at one classification. Here we get a few species suggested but the top species is correct, and has a significantly higher score than the second species. In this example we have not told the API what the organs are. The API can use this information to help give a better classification.
```{r multi2}
# This time I specify the organs in each image
identify(key,
imageURL = c(imageURL1, imageURL2, imageURL3),
organs = c('habit','bark','fruit'))
```
Notice that now the API knows which organs each image is of, we get slightly different results, the top species is the same but we can have higher confidence that this is the correct answer because the distance between the score of the first and second image is larger than before.