File size: 2,508 Bytes
0914710
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
5350122
0914710
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
from samgis import app_logger
from samgis.io.geo_helpers import get_vectorized_raster_as_geojson
from samgis.io.tms2geotiff import download_extent
from samgis.prediction_api.global_models import models_dict
from samgis.utilities.constants import DEFAULT_URL_TILES
from samgis_core.utilities.type_hints import llist_float, list_dict, dict_str_int
from lisa_on_cuda.utils import app_helpers


def lisa_predict(
        bbox: llist_float,
        prompt: str,
        zoom: float,
        inference_function_name_key: str = "lisa",
        source: str = DEFAULT_URL_TILES
) -> dict_str_int:
    """
    Return predictions as a geojson from a geo-referenced image using the given input prompt.

    1. if necessary instantiate a segment anything machine learning instance model
    2. download a geo-referenced raster image delimited by the coordinates bounding box (bbox)
    3. get a prediction image from the segment anything instance model using the input prompt
    4. get a geo-referenced geojson from the prediction image

    Args:
        bbox: coordinates bounding box
        prompt: machine learning input prompt
        zoom: Level of detail
        inference_function_name_key: machine learning model name
        source: xyz

    Returns:
        Affine transform
    """
    app_logger.info("start lisa inference...")
    if models_dict[inference_function_name_key]["inference"] is None:
        app_logger.info(f"missing inference function {inference_function_name_key}, instantiating it now!")
        parsed_args = app_helpers.parse_args([])
        inference_fn = app_helpers.get_inference_model_by_args(parsed_args)
        models_dict[inference_function_name_key]["inference"] = inference_fn
    app_logger.debug(f"using a {inference_function_name_key} instance model...")
    inference_fn = models_dict[inference_function_name_key]["inference"]

    pt0, pt1 = bbox
    app_logger.info(f"tile_source: {source}: downloading geo-referenced raster with bbox {bbox}, zoom {zoom}.")
    img, transform = download_extent(w=pt1[1], s=pt1[0], e=pt0[1], n=pt0[0], zoom=zoom, source=source)

    app_logger.info(
        f"img type {type(img)} with shape/size:{img.size}, transform type: {type(transform)}, transform:{transform}.")

    _, mask, output_string = inference_fn(prompt, img)
    # app_logger.info(f"created {n_predictions} masks, preparing conversion to geojson...")
    return {
        "output_string": output_string,
        **get_vectorized_raster_as_geojson(mask, transform)
    }