Python SDK toolkit for integrating Kindwise API into your application. This Python SDK provides a convenient way to interact with the Kindwise API for plant, insect, and mushroom identification. The SDK is organized into different modules, each corresponding to a specific domain (plant, insect, mushroom). You can always use our API without our SDK, the documentation can be found on the following links:
pip install kindwise-api-client
The API key serves to identify your account and is required to make requests to the API. Get API key at admin.kindwise.com.
To use Kindwise API, an active API key is needed. See the section above on how to get an API key.
from kindwise import PlantApi, PlantIdentification, UsageInfo
# initialize plant.id api
# "PLANT_API_KEY" environment variable can be set instead of specifying api_key
api = PlantApi(api_key='your_api_key')
# get usage information
usage: UsageInfo = api.usage_info()
# identify plant by image
latitude_longitude = (49.20340, 16.57318)
# pass the image as a path
image_path = 'path/to/plant_image.jpg'
# make identification
identification: PlantIdentification = api.identify(image_path, latitude_longitude=latitude_longitude)
# get identification by a token with changed views
# this method can be used to modify additional information in identification or to get identification from database
# also works with identification.custom_id
identification_with_different_views: PlantIdentification = api.get_identification(identification.access_token)
# delete identification
api.delete_identification(identification) # also works with identification.access_token or identification.custom_id
SDK supports the following Kindwise systems:
Each system has its class, which is used to make requests to the API. Each class has the following methods:
method | description | return type | plant.id | insect.id | mushroom.id | crop.health |
---|---|---|---|---|---|---|
identify |
create new identification | Identification |
âś… | âś… | âś… | âś… |
get_identification |
get identification by token | Identification |
âś… | âś… | âś… | âś… |
delete_identification |
delete identification by token | boolean | âś… | âś… | âś… | âś… |
usage_info |
get api key usage information | UsageInfo |
âś… | âś… | âś… | âś… |
feedback |
send feedback for identification | boolean | âś… | âś… | âś… | âś… |
health_assessment |
create health assessment identification | HealthAssessment |
✅ | ❌ | ❌ | ❌ |
get_health_assessment |
get health assessment identification | HealthAssessment |
✅ | ❌ | ❌ | ❌ |
delete_health_assessment |
delete health assessment | boolean | ✅ | ❌ | ❌ | ❌ |
available_details |
details which can be used to specify additional information for identify |
dict | âś… | âś… | âś… | âś… |
available_disease_details |
details which can be used to specify additional information for health_assessment |
dict | ✅ | ❌ | ❌ | ❌ |
search |
search for entity by query param in our database | SearchRecord |
✅ | ✅ | ✅ | ❌ |
get_kb_detail |
returns information about entity | dict |
✅ | ✅ | ✅ | ❌ |
ask_question |
conversation about the identification | Conversation |
✅ | ❌ | ❌ | ❌ |
get_conversation |
retrieve the identification's conversation | Conversation |
✅ | ❌ | ❌ | ❌ |
conversation_feedback |
set conversation's feedback | Conversation |
✅ | ❌ | ❌ | ❌ |
delete_conversation |
deletes the conversation | Conversation |
✅ | ❌ | ❌ | ❌ |
Datetime objects are created by method datetime.fromtimestamp(timestamp)
. This means that datetime objects are in
local timezone.
Returns details which can be used to specify additional information for identify
method. `
from kindwise import PlantApi
api = PlantApi()
available_details = api.available_details()
Creates a new identification. In one identification, you can include up to 5 images.
import base64
from datetime import datetime
from kindwise import PlantApi, PlantIdentification, ClassificationLevel
api = PlantApi(api_key='your_api_key')
# this creates one identification composed of 5 images(not 5 different identifications)
#
# as input image is accepted path to an image(str / pathlib.Path), base64 encoded stream(bytes/string), stream(bytes/string),
# or file object(supports read,seek and mode methods)
# or PIL.Image.Image object
# or list of images
images = ['path/to/image1.jpg', 'path/to/image2.jpg', 'path/to/image3.jpg', 'path/to/image4.jpg', 'path/to/image5.jpg']
# details included in identification
details = ['common_names', 'taxonomy', 'image']
# disease details included in health identification(only used if health=True)
# disease_details parameter is only available for plant.id
disease_details = ['local_name', 'description', 'treatment', 'cause']
# specify up to 3 languages
language = ['en', 'cs']
# default for similar_images is True
similar_images = True
# where was an image taken
latitude_longitude = (49.20340, 16.57318)
# include health assessment in your identification by specifying health='all',
# also use health='only' to get HealthAssessment(health assessment only)
# health assessment is only available for plant.id
health = 'all'
# custom id is used to identify identification in your system, but can be replaced with access_token
custom_id = 123
# when was an image taken, datetime can be specified as a datetime object, timestamp, or string in ISO format
date_time = datetime.now()
# default image size is 1500px, can be turned off by setting max_image_size to None
# be aware that our API has limit 25Mpx(e.g. 5000px x 5000px)
max_image_size = 1500
# specify into what depth should be the plant classified
# choose from ClassificationLevel.SPECIES, ClassificationLevel.GENUS, ClassificationLevel.ALL
# default is ClassificationLevel.SPECIES
classification_level = ClassificationLevel.SPECIES
# in case of need to merge results for different taxon levels yourself, set classification_raw=True
# be aware that the result will be in type kindwise.models.RawPlantIdentification
classification_raw = False
# if our api will be ahead of this sdk and you do not want to wait for update,
# specify extra_get_params or extra_post_params
extra_get_params = None # default
extra_post_params = None # default
identification: PlantIdentification = api.identify(
images,
details=details,
disease_details=disease_details,
language=language,
similar_images=similar_images,
latitude_longitude=latitude_longitude,
health=health,
custom_id=custom_id,
date_time=date_time,
max_image_size=max_image_size,
classification_level=classification_level,
classification_raw=classification_raw,
extra_get_params=extra_get_params,
extra_post_params=extra_post_params,
)
# identification created from stream
with open('path/to/image.jpg', 'rb') as image:
identification_from_stream: PlantIdentification = api.identify(image.read())
# identification created from file object
with open('path/to/image.jpg', 'rb') as image:
identification_from_file: PlantIdentification = api.identify(image)
# identification created from base64 encoded image
with open('path/to/image.jpg', 'rb') as image:
image_in_base64 = base64.b64encode(image.read())
identification_from_base64: PlantIdentification = api.identify(image)
# identification created from PIL.Image.Image object
from PIL import Image
image = Image.open('path/to/image.jpg')
identification_from_pil: PlantIdentification = api.identify(image)
# identification created from image url
image_url = 'https://api.gbif.org/v1/image/cache/fit-in/500x/occurrence/4596837568/media/33ff3ad210e56b73ade6f9fe622c650e'
identification_from_url: PlantIdentification = api.identify(image_url)
When you don't want to wait until the identification is finished, you can specify asynchronous=True
and
get access_token
or custom_id
if specified and retrieve the answer later.
from kindwise import PlantApi, PlantIdentification
api = PlantApi(api_key='your_api_key')
image = 'path/to/image.jpg'
identification: PlantIdentification = api.identify(image, asynchronous=True)
# now do something else
# ...
# and later get identification by access_token or custom_id
identification: PlantIdentification = api.get_identification(identification.access_token, details=['common_names'])
Get identification by token. You can specify which details you want to get. We store your identifications for 6 months.
from kindwise import PlantApi, PlantIdentification
api = PlantApi(api_key='your_api_key')
access_token = 'identification_access_token'
# details included in identification, can be different from used in identification create
details = ['common_names', 'taxonomy', 'image']
# language can also differ from used in identification create
language = 'de'
identification: PlantIdentification = api.get_identification(access_token, details=details, language=language)
Deletes identification from our database. You can specify identification by access_token or custom_id.
from kindwise import PlantApi
api = PlantApi(api_key='your_api_key')
custom_id = 123 # also works with access_token or Identification object
api.delete_identification(custom_id)
Gives you information about your api key usage.
from kindwise import PlantApi, UsageInfo
api = PlantApi(api_key='your_api_key')
usage_info: UsageInfo = api.usage_info()
Send feedback for identification. You can specify a comment(string) or rating(int) in feedback. At least one of comment and rating must be specified. You can specify identification by access_token or custom_id.
from kindwise import PlantApi
api = PlantApi(api_key='your_api_key')
custom_id = 123 # also works with access_token or Identification object
api.feedback(custom_id, comment='comment', rating=5)
Returns details which can be used to specify additional information for health_assessment
method. Only available for
plant.id.
from kindwise import PlantApi
api = PlantApi()
available_disease_details = api.available_disease_details()
Returns only health assessment for identification. Health assessment is only available for plant.id. health_assessment
method is similar to identify
method, but it returns only health assessment. Details differs for each system.
from datetime import datetime
from kindwise import PlantApi, HealthAssessment
api = PlantApi(api_key="your_api_key")
# the same as in identify method
images = [
"path/to/image1.jpg",
"path/to/image2.jpg",
"path/to/image3.jpg",
"path/to/image4.jpg",
"path/to/image5.jpg",
]
# details included in identification
details = ["local_name", "description", "treatment", "cause", "image"]
# specify up to 3 languages
language = ["en", "cs"]
# default for similar_images is True
similar_images = True
# where was an image taken
latitude_longitude = (49.20340, 16.57318)
# custom id is used to identify identification in your system, but can be replaced with access_token
custom_id = 123
# list of suggested diseases also contains general diseases such as "Abiotic", default is False
full_disease_list = True
# when was an image taken, datetime can be specified as a datetime object, timestamp, or string in ISO format
date_time = datetime.now()
# default image size is 1500px, can be turned off by setting max_image_size to None
# be aware that our API has limit 25Mpx(e.g. 5000px x 5000px)
max_image_size = 1500
# if our api will be ahead of this sdk and you do not want to wait for update,
# specify extra_get_params or extra_post_params
extra_get_params = None # default
extra_post_params = None # default
identification: HealthAssessment = api.health_assessment(
images,
details=details,
language=language,
similar_images=similar_images,
latitude_longitude=latitude_longitude,
custom_id=custom_id,
full_disease_list=full_disease_list,
date_time=date_time,
max_image_size=max_image_size,
)
When you don't want to wait until the identification is finished, you can specify asynchronous=True
similar
to identify
method.
Get a health assessment for identification. You can specify which details you want to get. We store your identifications for 6 months.
from kindwise import PlantApi, HealthAssessment
api = PlantApi(api_key='your_api_key')
access_token = 'identification_access_token'
# details included in identification can be different from those used in identification creation
details = ['classification', 'local_name']
# language can also differ from what is used in identification creation
language = 'de'
full_disease_list = False
identification: HealthAssessment = api.get_health_assessment(
access_token,
details=details,
language=language,
full_disease_list=full_disease_list
)
Delete health assessment for identification.
from kindwise import PlantApi
api = PlantApi(api_key='your_api_key')
custom_id = 123 # also works with access_token or HealthAssessment object
api.delete_health_assessment(custom_id)
Search for entity(e.g. Taraxacum
) by query param in our database. You can specify language, limit and database type.
from kindwise import PlantApi, SearchResult, PlantKBType
api = PlantApi(api_key='your_api_key')
kb_type = PlantKBType.PLANTS
limit = 10
search_result: SearchResult = api.search('Taraxacum', language='en', kb_type=kb_type, limit=limit)
Returns information about entity(e.g. Taraxacum
) in our database. You can specify in what language you want the
result.
from kindwise import PlantApi, SearchResult
api = PlantApi(api_key='your_api_key')
search_result: SearchResult = api.search('Taraxacum', language='en', limit=1)
# details can also be specified as a list of strings
details = 'common_names,taxonomy'
entity_details = api.get_kb_detail(search_result.entities[0].access_token, details, language='de')
Ask a question to our ChatBot. ChatBot supports multiple backends and its configuration can be modified.
from kindwise import PlantApi, Conversation
api = PlantApi(api_key="your_api_key")
# Firstly you need to have an access_token of identification about which you want to ask the question
identification = "identification_access_token"
# question is a question that you want to ask the ChatBot
question = "Is this plant edible?"
# model is a parameter that controls the model used for generating the answer. List of models can be found in the documentation.
model = "gpt-3.5-turbo.demo"
# You can specify an app name that will be used for chat-bot to specify who is he
app_name = "my_app"
# You can specify a prompt that will be used together with our prompt to generate the answer.
prompt = "You are an assistant for a plant identification app. Please answer the user's question."
# Temperature is a parameter that controls the randomness of the model.
# The higher the temperature, the more random the output.
temperature = 0.0
# The configuration parameters: model, app_name, prompt, temperature are optional
# and can be specified only for the first question.
conversation: Conversation = api.ask_question(
identification,
question,
model=model,
app_name=app_name,
prompt=prompt,
temperature=temperature,
)
# You can set a conversation's feedback(JSON)
api.conversation_feedback(identification, {'rating': 5, 'comment': 'Great conversation!'})
# You can retrieve the conversation later
# You can also delete the conversation
api.delete_conversation(identification)
from kindwise import PlantApi, Conversation
api = PlantApi(api_key='your_api_key')
# Firstly you need to have an access_token of identification about which you want to ask the question
identification = "identification_access_token"
conversation: Conversation = api.get_conversation(identification)
from kindwise import PlantApi, Conversation
api = PlantApi(api_key='your_api_key')
# Firstly you need to have an access_token of identification about which you want to ask the question
identification = "identification_access_token"
# You can set a conversation's feedback(JSON)
api.conversation_feedback(identification, {'rating': 5, 'comment': 'Great conversation!'})
from kindwise import PlantApi, Conversation
api = PlantApi(api_key='your_api_key')
# Firstly you need to have an access_token of identification about which you want to ask the question
identification = "identification_access_token"
# You can also delete the conversation
api.delete_conversation(identification)