PolarEcgDataLogger.cs 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Globalization;
  4. using Sensors;
  5. using Sensors.Polar;
  6. using UniRx;
  7. using UnityEngine;
  8. namespace Logging
  9. {
  10. public readonly struct PolarSensorEcgLog
  11. {
  12. private readonly int timestamp;
  13. private readonly float ecg;
  14. public PolarSensorEcgLog(int timestamp, float ecg)
  15. {
  16. this.timestamp = timestamp;
  17. this.ecg = ecg;
  18. }
  19. public string[] Serialize() =>
  20. new[]
  21. {
  22. timestamp.ToString("D", CultureInfo.InvariantCulture),
  23. ecg.ToString("F4", CultureInfo.InvariantCulture)
  24. };
  25. }
  26. public class PolarEcgDataLogger : SensorDataLogger<PolarSensorEcgLog>
  27. {
  28. public override string Key => "polar_ecg_data";
  29. private long startTime = -1;
  30. private TimeSync timeSync;
  31. private const int ECG_SAMPLE_RATE = 130;
  32. private IDisposable sub;
  33. public override async void Start()
  34. {
  35. base.Start();
  36. timeSync = new TimeSync
  37. {
  38. StartTime = DateTime.Now,
  39. DifDataStreamStart = -1
  40. };
  41. var bikeSensorData = BikeSensorData.Instance;
  42. await bikeSensorData.PolarReceiverAvailable;
  43. sub = bikeSensorData.RawEcgData?.Subscribe(data => OnData(data));
  44. }
  45. private void OnData(in EcgData data)
  46. {
  47. if (timeSync.DifDataStreamStart < 0)
  48. {
  49. timeSync.DifDataStreamStart = (long) (DateTime.Now - timeSync.StartTime).TotalMilliseconds;
  50. }
  51. if (startTime < 0)
  52. {
  53. startTime = data.Timestamp;
  54. }
  55. var internalTimestamp =
  56. (data.Timestamp - startTime) / 1000000;
  57. var timestamp = Mathf.RoundToInt(internalTimestamp + timeSync.DifDataStreamStart);
  58. foreach (var item in data.Values)
  59. {
  60. Log(new PolarSensorEcgLog(timestamp, item));
  61. timestamp += 1000 / ECG_SAMPLE_RATE;
  62. }
  63. }
  64. public override void Log(PolarSensorEcgLog value)
  65. {
  66. Buffer.Add(value.Serialize());
  67. }
  68. public override IEnumerable<PolarSensorEcgLog> ReadLog(IEnumerable<IEnumerable<string>> lines)
  69. {
  70. throw new System.NotImplementedException(); //TODO
  71. }
  72. private void OnDestroy()
  73. {
  74. sub?.Dispose();
  75. }
  76. }
  77. }