Mobile AR Sensor (MARS) Logger
record camera frames at ~30Hz and inertial measurement unit (IMU) measurements at ~100Hz synced to one clock source on Android (API 21+) and iOS (SDK 8.0+) mobile devices.
New features
The Android app of MARS logger is upgraded in the user interface. Now the user can specify the exposure time, ISO, camera frame size, camera ID. By navigating between tabs, the user can capture videos + IMU data, or capture images of a constant focus distance. Also the tap to focus function is corrected. The app is released at here
An Android app to capture data with the fisheye camera and the IMU on tango devices, e.g., Lenovo Phab2 Pro, Asus ZenFone AR, has been released with source code at here.
Description
Android
The Android app is developed from the CameraCaptureActivity of the grafika project.
- Camera frames are saved into H.264/MP4 videos by using the Camera2 API (setRepeatingRequest, onCaptureCompleted), OpenGL ES (GLSurfaceView and GLSurfaceView.Renderer), and MediaCodec and MediaMuxer.
- The metadata for camera frames are saved to a csv.
- The timestamps for each camera frame are saved to a txt.
- Inertial data are recorded on a background HandlerThread.
iOS
The iOS app is developed from the rosywriter in objective C with iOS SDK 8.0 released by Apple.
- Camera frames are saved into H.264/MP4 videos by using AVCaptureVideoDataOutput and AVAssetWriter.
- Timestamps, camera projection intrinsic parameters, exposure duration of the camera frame are saved into a csv file.
- Inertial data are saved into a csv by a background NSOperationQueue receiving data from the CMMotionManager.
For user guide, please visit the wiki.
Features
- 25+ Hz camera frames and 100+ Hz IMU measurements for off-the-shelf smartphones priced $200+.
- The visual and inertial data are synchronized to one clock.
- The focal length in pixels and exposure duration are recorded.
- Tap to lock auto focus and auto exposure so as to fix focus distance and exposure duration.
Get started
The installation, data format, recording and exporting data are explained in the following wiki pages.
Android
- Installation
- Record data
- Data format
- Example data
- Transfer data to Windows
- Transfer data to Ubuntu
- Clear data
- Bag data
iOS
- Installation
- Record data
- Data format
- Example data
- Transfer data to Windows
- Transfer data to MacOS
- Clear data
- Bag data
Citing
If you use the logger for your research, please consider citing the paper.
@INPROCEEDINGS{huai2019mars,
author={Jianzhu {Huai} and Yujia {Zhang} and Alper {Yilmaz}},
booktitle={2019 IEEE SENSORS},
title={The mobile AR sensor logger for Android and iOS devices},
year={2019},
volume={},
number={},
pages={},
ISSN={},
month={Oct},}