Spaces:
Running
Running
File size: 2,377 Bytes
da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 8ccf878 22a27a1 da8bdb9 8ccf878 da8bdb9 8ccf878 da8bdb9 |
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 |
# -*- coding: utf-8 -*-
"""SaliencyMapใ่จ็ฎใใ"""
from typing import Any, Tuple, Literal
import numpy as np
import cv2
class SaliencyMap:
"""
SaliencyMap ้ก่ๆงใใใใ่จ็ฎใใใฏใฉในใงใใ
Example:
from lib.saliency import SaliencyMap
saliency = SaliencyMap("SpectralResidual")
success, saliencyMap = saliency.compute(image)
"""
def __init__(
self,
algorithm: Literal["SpectralResidual", "FineGrained"] = "SpectralResidual",
):
self.algorithm = algorithm
# OpenCVใฎsaliencyใไฝๆใใพใใ
if algorithm == "SpectralResidual":
self.saliency = cv2.saliency.StaticSaliencySpectralResidual_create()
else:
self.saliency = cv2.saliency.StaticSaliencyFineGrained_create()
def compute(self, image: np.ndarray) -> Tuple[bool, Any]:
"""
ๅ
ฅๅ็ปๅใใ้ก่ๆงใใใใไฝๆใใพใใ
Parameters:
image: ๅ
ฅๅ็ปๅ
Returns:
bool:
true: SaliencyMap computed, false:NG
np.ndarray: ้ก่ๆงใใใ
"""
# ็ปๅใฎ้ก่ๆงใ่จ็ฎใใพใใ
return self.saliency.computeSaliency(image)
def convert_colormap(
image: np.ndarray,
saliency_map: np.ndarray,
colormap_name: Literal["jet", "hot", "turbo"] = "jet"
):
"""
้ก่ๆงใใใใใซใฉใผใใใใซๅคๆๅพใซใๅ
ฅๅ็ปๅใซ้ใญๅใใใใพใใ
Parameters:
image: ๅ
ฅๅ็ปๅ
saliency_map: ้ก่ๆงใใใ
colormap_name: ใซใฉใผใใใใฎ็จฎ้ก
Returns:
np.ndarray: ้ใญๅใใใ็ปๅ(RGBAๅฝขๅผ)
"""
maps = {"jet": cv2.COLORMAP_JET, "hot": cv2.COLORMAP_HOT, "turbo": cv2.COLORMAP_TURBO}
if colormap_name not in maps:
raise ValueError(colormap_name)
# ้ก่ๆงใใใใใซใฉใผใใใใซๅคๆ
saliency_map = (saliency_map * 255).astype("uint8")
saliency_map = cv2.applyColorMap(saliency_map, maps[colormap_name])
#return saliencyMap
# ๅ
ฅๅ็ปๅใจใซใฉใผใใใใ้ใญๅใใ
overlay = cv2.addWeighted(image, 0.5, saliency_map, 0.5, 0)
#return overlay
return cv2.cvtColor(overlay, cv2.COLOR_BGR2RGBA)
|