| /* |
| * Copyright The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package android.hardware.cts.helpers.sensorTestOperations; |
| |
| import junit.framework.Assert; |
| |
| import android.content.Context; |
| import android.hardware.cts.helpers.SensorCtsHelper; |
| import android.hardware.cts.helpers.SensorManagerTestVerifier; |
| import android.hardware.cts.helpers.SensorTestInformation; |
| import android.hardware.cts.helpers.SensorTestOperation; |
| import android.hardware.cts.helpers.TestSensorEvent; |
| |
| import java.security.InvalidParameterException; |
| |
| /** |
| * Test Operation class that validates the sign of measurements of a a given sensor. |
| * The operation relies in the number of axes each sensor type reports. |
| */ |
| public class VerifySignumOperation extends SensorTestOperation { |
| private final SensorManagerTestVerifier mSensor; |
| private final int mAxisCount; |
| private final double mReferenceValues[]; |
| private final double mNoiseThreshold; |
| |
| /** |
| * @param noiseThreshold Defines the threshold that needs to be crossed to consider a |
| * measurement different from zero |
| */ |
| public VerifySignumOperation( |
| Context context, |
| int sensorType, |
| int samplingRateInUs, |
| double referenceValues[], |
| double noiseThreshold) { |
| mAxisCount = SensorTestInformation.getAxisCount(sensorType); |
| if(mAxisCount != referenceValues.length) { |
| throw new InvalidParameterException( |
| String.format("%d reference values are expected.", mAxisCount)); |
| } |
| for(int i = 0; i < referenceValues.length; ++i) { |
| double value = referenceValues[i]; |
| if(value != 0 && value != -1 && value != +1) { |
| throw new InvalidParameterException( |
| "A ReferenceValue can only be one of the following: -1, 0, +1"); |
| } |
| } |
| mSensor = new SensorManagerTestVerifier( |
| context, |
| sensorType, |
| samplingRateInUs, |
| 0 /*reportLatencyInUs*/); |
| // set expectations |
| mReferenceValues = referenceValues; |
| mNoiseThreshold = noiseThreshold; |
| } |
| |
| @Override |
| public void doWork() { |
| final String VALUE_SEPARATOR = ", "; |
| TestSensorEvent events[] = mSensor.collectEvents(100); |
| double measuredValues[] = new double[mReferenceValues.length]; |
| SensorCtsHelper.getMeans(events, measuredValues); |
| |
| boolean success = true; |
| StringBuilder referenceValuesBuilder = new StringBuilder(); |
| StringBuilder measuredValuesBuilder = new StringBuilder(); |
| for(int i = 0; i < mReferenceValues.length; i++) { |
| double reference = mReferenceValues[i]; |
| double measurement = measuredValues[i]; |
| if(reference == 0) { |
| success &= Math.abs(measurement) < mNoiseThreshold; |
| } else { |
| double combinedValue = reference * measurement; |
| if(combinedValue < mNoiseThreshold) { |
| combinedValue = 0; |
| } |
| success &= combinedValue > 0; |
| } |
| referenceValuesBuilder.append(reference); |
| referenceValuesBuilder.append(VALUE_SEPARATOR); |
| measuredValuesBuilder.append(measurement); |
| measuredValuesBuilder.append(VALUE_SEPARATOR); |
| } |
| if(!success) { |
| String message = SensorCtsHelper.formatAssertionMessage( |
| "Measurement", |
| this, |
| mSensor.getUnderlyingSensor(), |
| "expected:( %s), actual:( %s), noiseThreshold:%f", |
| referenceValuesBuilder.toString(), |
| measuredValuesBuilder.toString(), |
| mNoiseThreshold); |
| Assert.fail(message); |
| } |
| } |
| } |