EngSrc/IESensorDataFilter.cpp
author jkauppin
Fri, 15 Oct 2010 10:18:29 +0900
changeset 3 93fff7023be8
permissions -rw-r--r--
Initial version
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
3
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     1
/*
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     2
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     3
* All rights reserved.
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     4
* This component and the accompanying materials are made available
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     6
* which accompanies this distribution, and is available
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     8
*
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
     9
* Initial Contributors:
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    11
*
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    12
* Contributors: Juha Kauppinen, Mika Hokkanen
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    13
* 
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    14
* Description: Photo Browser
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    15
*
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    16
*/
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    17
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    18
#include "IESensorDataFilter.h"
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    19
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    20
CIESensorDataFilter::CIESensorDataFilter()
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    21
    {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    22
    // No implementation required
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    23
    }
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    24
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    25
CIESensorDataFilter::~CIESensorDataFilter()
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    26
    {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    27
    delete iRingBuffer;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    28
    }
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    29
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    30
CIESensorDataFilter* CIESensorDataFilter::NewLC()
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    31
    {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    32
    CIESensorDataFilter* self = new (ELeave) CIESensorDataFilter();
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    33
    CleanupStack::PushL(self);
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    34
    self->ConstructL();
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    35
    return self;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    36
    }
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    37
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    38
CIESensorDataFilter* CIESensorDataFilter::NewL()
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    39
    {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    40
    CIESensorDataFilter* self = CIESensorDataFilter::NewLC();
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    41
    CleanupStack::Pop(); // self;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    42
    return self;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    43
    }
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    44
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    45
void CIESensorDataFilter::ConstructL()
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    46
    {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    47
    iRingBuffer = new (ELeave) TInt[KDataBufferSize];
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    48
    
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    49
    memset(iRingBuffer, '\0', KDataBufferSize * sizeof (TInt));
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    50
    
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    51
    iRingBufferPointer = iRingBuffer;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    52
    
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    53
    }
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    54
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    55
TInt CIESensorDataFilter::FilterSensorData(TInt aNewValue)
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    56
    {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    57
    // Returns the average of the measures inside the circular buffer avoiding the noise  
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    58
    
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    59
    *iRingBufferPointer = aNewValue;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    60
    
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    61
    iRingBufferPointer++;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    62
    
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    63
    if(iRingBufferPointer >= (iRingBuffer + (KDataBufferSize - 1 )))
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    64
        {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    65
        iRingBufferPointer = iRingBuffer;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    66
        }
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    67
    
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    68
    TInt sum = 0;
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    69
    for (TInt i = 0; i < KDataBufferSize; i++ )
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    70
        {
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    71
        sum = sum + iRingBuffer[i];
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    72
        }
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    73
        
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    74
    return (sum / KDataBufferSize);
93fff7023be8 Initial version
jkauppin
parents:
diff changeset
    75
    }