################################################################################
# COPYRIGHT(c) 2018 STMicroelectronics                                         #
#                                                                              #
# Redistribution and use in source and binary forms, with or without           #
# modification, are permitted provided that the following conditions are met:  #
#   1. Redistributions of source code must retain the above copyright notice,  #
#      this list of conditions and the following disclaimer.                   #
#   2. Redistributions in binary form must reproduce the above copyright       #
#      notice, this list of conditions and the following disclaimer in the     #
#      documentation and/or other materials provided with the distribution.    #
#   3. Neither the name of STMicroelectronics nor the names of its             #
#      contributors may be used to endorse or promote products derived from    #
#      this software without specific prior written permission.                #
#                                                                              #
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"  #
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE    #
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE   #
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE    #
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR          #
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF         #
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS     #
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN      #
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)      #
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE   #
# POSSIBILITY OF SUCH DAMAGE.                                                  #
################################################################################
# IMPORT
from enum import Enum
from blue_st_sdk.feature import Feature
from blue_st_sdk.feature import Sample
from blue_st_sdk.feature import ExtractedData
from blue_st_sdk.features.field import Field
from blue_st_sdk.features.field import FieldType
from blue_st_sdk.utils.number_conversion import NumberConversion
from blue_st_sdk.utils.blue_st_exceptions import BlueSTInvalidDataException
from blue_st_sdk.utils.python_utils import lock
# CLASSES
[docs]class SceneType(Enum):
    """Type of scene."""
    UNKNOWN = -1
    INDOOR = 0
    OUTDOOR = 1
    IN_VEHICLE = 2 
    ERROR = 3
[docs]class FeatureAudioSceneClassification(Feature):
    """The feature handles the type of scene that can be detected by a device.
    Data is one byte long and has no decimal digits.
    """
    FEATURE_NAME = "Audio Scene Classification"
    FEATURE_UNIT = None
    FEATURE_DATA_NAME = "SceneType"
    DATA_MAX = 3
    DATA_MIN = 0
    FEATURE_FIELDS = Field(
        FEATURE_DATA_NAME,
        FEATURE_UNIT,
        FieldType.UInt8,
        DATA_MAX,
        DATA_MIN)
    DATA_LENGTH_BYTES = 1
[docs]    def __init__(self, node):
        """Constructor.
        Args:
            node (:class:`blue_st_sdk.node.Node`): Node that will send data to
                this feature.
        """
        super(FeatureAudioSceneClassification, self).__init__( 
            self.FEATURE_NAME, node, [self.FEATURE_FIELDS])
        return ExtractedData(sample, self.DATA_LENGTH_BYTES)
[docs]    @classmethod
    def get_scene(self, sample):
        """Getting the scene from a sample.
        Args:
            sample (:class:`blue_st_sdk.feature.Sample`): Sample data.
        Returns:
            :class:`SceneType`: The type of the scene if the sample is valid,
            "SceneType.ERROR" otherwise.
        """
        if sample is not None:
            if sample._data:
                if sample._data[0] is not None:
                    return SceneType(sample._data[0]) 
        return SceneType.ERROR
    def __str__(self):
        """Get a string representing the last sample.
        Return:
            str: A string representing the last sample.
        """
        with lock(self):
            sample = self._last_sample
        if sample is None:
            return self._name + ': Unknown'
        if not sample._data:
            return self._name + ': Unknown'
        if len(sample._data) == 1:
            result = '%s(%d): Scene is \"%s\"' \
                
% (self._name,
                   sample._timestamp,
                   str(self.get_scene(sample))
                   ) 
        return result