我一直在使用Sony Smartwatch 3记录长时间(平均8小时)的加速度计数据。以下是主要代码块:ax,ay和az是用于存储传感器值的数组列表,而ta是具有相应时间戳的数组列表。

private void startMeasurement() {
    mSensorManager = ((SensorManager) getSystemService(SENSOR_SERVICE));
    Log.d("lister", "listeners");
    Sensor accelerometerSensor = mSensorManager.getDefaultSensor(SENS_ACCELEROMETER);

    // Register the listener
    if (mSensorManager != null) {
        mSensorManager.registerListener(this, accelerometerSensor,25000);
    }
}

    @Override
public void onSensorChanged(SensorEvent event) {
    if(event.sensor.getType() == SENS_ACCELEROMETER){
        ax.add(event.values[0]);
        ay.add(event.values[1]);
        az.add(event.values[2]);
        ta.add(System.currentTimeMillis());
    }

}

public void write(){
    String timeStamp = new SimpleDateFormat("yyMMdd_HHmmss").format(Calendar.getInstance().getTime());
    File file = new File(Environment.getExternalStorageDirectory().getAbsolutePath() + "/sensor_data/" + timeStamp + ".csv");
    try{
        FileWriter fw = new FileWriter(file);
        BufferedWriter buffWriter = new BufferedWriter(fw,50*1024);
        for(int i=0;i<ax.size();i++){
            buffWriter.write(String.valueOf(ax.get(i)));
            buffWriter.write(",");
            buffWriter.write(String.valueOf(ay.get(i)));
            buffWriter.write(",");
            buffWriter.write(String.valueOf(az.get(i)));
            buffWriter.write(",");
            buffWriter.write(String.valueOf(ta.get(i)));
            buffWriter.write("\n");
        }
        buffWriter.flush();
        buffWriter.close();
    }catch (IOException e){
        e.printStackTrace();
    }

}


当查看样本之间的时间差时,我注意到在记录数据一段时间后该时间增加了。在下面的链接中,您可以查看以秒为单位的样本之间的时间差图。
java - Android Smartwatch采样频率-LMLPHP

为什么一段时间记录后差异突然跳到50?

最佳答案

最终通过使用Android的PowerManager和PARTIAL_WAKE_LOCK解决了该问题。它消耗更多的电池,但我确实需要使采样频率保持几乎恒定。

10-04 19:15