last built 2019-07-23
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/.
To install the development version of this package from Github use this code.
# Install using the devtools package
devtools::install_github(repo = 'BiologicalRecordsCentre/plantnet')
library(plantnet)
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/.
With these we can do a single image classification like this. Here we use this photo of a lavender
# Get your key from https://my.plantnet.org/
key <- "YOUR_SUPER_SECRET_KEY"
# 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'
classifications <- identify(key, imageURL)
classifications
## score latin_name common_name
## [1,] 35.92154 "Lavandula dentata" "French lavender"
## [2,] 31.78688 "Lavandula angustifolia" "Lavender"
## [3,] 18.06659 "Lavandula stoechas" "Topped lavender"
## [4,] 6.717049 "Lavandula latifolia" "Broadleaf lavender"
## [5,] 1.665378 "Perovskia atriplicifolia" "Russian-sage"
## [6,] 1.022022 "Lavandula pinnata" NA
## [7,] 0.5533172 "Vitex agnus-castus" "Chasteberry"
## [8,] 0.5320209 "Salvia farinacea" "Mealy sage"
## [9,] 0.485067 "Lavandula multifida" "Fern-leaf lavender"
## [10,] 0.3812005 "Lavandula canariensis" NA
## [11,] 0.2864826 "Nepeta tuberosa" NA
## [12,] 0.1719182 "Lavandula minutolii" NA
## [13,] 0.1427725 "Perovskia abrotanoides" "Russian Sage"
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
.
classifications <- identify(key, imageURL, simplify = FALSE)
str(classifications,1)
## List of 4
## $ query :List of 3
## $ language : chr "en"
## $ preferedReferential: chr "florefrance"
## $ results :List of 13
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.
classifications$results[[1]]
## $score
## [1] 35.92154
##
## $species
## $species$scientificNameWithoutAuthor
## [1] "Lavandula dentata"
##
## $species$scientificNameAuthorship
## [1] "L."
##
## $species$genus
## $species$genus$scientificNameWithoutAuthor
## [1] "Lavandula"
##
## $species$genus$scientificNameAuthorship
## [1] "L."
##
##
## $species$family
## $species$family$scientificNameWithoutAuthor
## [1] "Lamiaceae"
##
## $species$family$scientificNameAuthorship
## [1] ""
##
##
## $species$commonNames
## $species$commonNames[[1]]
## [1] "French lavender"
##
## $species$commonNames[[2]]
## [1] "Spanish Lavender"
Here we have information on the Latin name, authors, and at the end, a list of the common names.
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.
# 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))
## score latin_name common_name
## [1,] 68.28053 "Quercus robur" "Pedunculate oak"
## [2,] 28.3852 "Terminalia catappa" "Indian-almond"
## [3,] 19.02534 "Quercus petraea" "Sessile oak"
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.
# This time I specify the organs in each image
identify(key,
imageURL = c(imageURL1, imageURL2, imageURL3),
organs = c('habit','bark','fruit'))
## score latin_name common_name
## [1,] 68.28053 "Quercus robur" "Pedunculate oak"
## [2,] 19.02534 "Quercus petraea" "Sessile oak"
## [3,] 18.92347 "Terminalia catappa" "Indian-almond"
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.