profile-prepare.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. //для pumpprofile.json параметры: settings/settings.json settings/bg_targets.json settings/insulin_sensitivities.json settings/basal_profile.json preferences.json settings/carb_ratios.json settings/temptargets.json settings/model.json
  2. //для profile.json параметры: settings/settings.json settings/bg_targets.json settings/insulin_sensitivities.json settings/basal_profile.json preferences.json settings/carb_ratios.json settings/temptargets.json settings/model.json settings/autotune.json
  3. function generate(pumpsettings_data, bgtargets_data, isf_data, basalprofile_data, preferences_input = false, carbratio_input = false, temptargets_input = false, model_input = false, autotune_input = false, trio_data, clock_input = false) {
  4. if (bgtargets_data.units !== 'mg/dL') {
  5. if (bgtargets_data.units === 'mmol/L') {
  6. for (var i = 0, len = bgtargets_data.targets.length; i < len; i++) {
  7. bgtargets_data.targets[i].high = bgtargets_data.targets[i].high * 18;
  8. bgtargets_data.targets[i].low = bgtargets_data.targets[i].low * 18;
  9. }
  10. bgtargets_data.units = 'mg/dL';
  11. } else {
  12. return { "error" : 'BG Target data is expected to be expressed in mg/dL or mmol/L. Found '+ bgtargets_data.units };
  13. }
  14. }
  15. if (isf_data.units !== 'mg/dL') {
  16. if (isf_data.units === 'mmol/L') {
  17. for (var i = 0, len = isf_data.sensitivities.length; i < len; i++) {
  18. isf_data.sensitivities[i].sensitivity = isf_data.sensitivities[i].sensitivity * 18;
  19. }
  20. isf_data.units = 'mg/dL';
  21. } else {
  22. return { "error" : 'ISF is expected to be expressed in mg/dL or mmol/L. Found '+ isf_data.units };
  23. }
  24. }
  25. var autotune_data = { };
  26. if (autotune_input) {
  27. autotune_data = autotune_input;
  28. }
  29. var temptargets_data = { };
  30. if (temptargets_input) {
  31. temptargets_data = temptargets_input;
  32. }
  33. var trioData = { };
  34. if (trio_data) {
  35. trioData = trio_data;
  36. }
  37. var clock = null;
  38. if (clock_input) {
  39. clock = new Date(clock_input);
  40. }
  41. var model_data = { };
  42. if (model_input) {
  43. model_data = model_input.replace(/"/gi, '');
  44. }
  45. var carbratio_data = { };
  46. if (carbratio_input) {
  47. var errors = [ ];
  48. if (!(carbratio_input.schedule && carbratio_input.schedule[0].start && carbratio_input.schedule[0].ratio)) {
  49. errors.push("Carb ratio data should have an array called schedule with a start and ratio fields.");
  50. }
  51. if (carbratio_input.units !== 'grams' && carbratio_input.units !== 'exchanges') {
  52. errors.push("Carb ratio should have units field set to 'grams' or 'exchanges'.");
  53. }
  54. if (errors.length) {
  55. return { "error" : errors.join(' ') };
  56. }
  57. carbratio_data = carbratio_input;
  58. }
  59. var preferences = { };
  60. if (preferences_input) {
  61. preferences = preferences_input;
  62. if (preferences.curve === "rapid-acting") {
  63. if (preferences.useCustomPeakTime) {
  64. preferences.insulinPeakTime =
  65. Math.max(50, Math.min(preferences.insulinPeakTime, 120));
  66. } else { preferences.insulinPeakTime = 75; }
  67. }
  68. else if (preferences.curve === "ultra-rapid") {
  69. if (preferences.useCustomPeakTime) {
  70. preferences.insulinPeakTime =
  71. Math.max(35, Math.min(preferences.insulinPeakTime, 100));
  72. } else { preferences.insulinPeakTime = 55; }
  73. }
  74. }
  75. var inputs = { };
  76. //add all preferences to the inputs
  77. for (var pref in preferences) {
  78. if (preferences.hasOwnProperty(pref)) {
  79. inputs[pref] = preferences[pref];
  80. }
  81. }
  82. inputs.max_iob = inputs.max_iob || 0;
  83. //set these after to make sure nothing happens if they are also set in preferences
  84. inputs.settings = pumpsettings_data;
  85. inputs.targets = bgtargets_data;
  86. inputs.basals = basalprofile_data;
  87. inputs.isf = isf_data;
  88. inputs.carbratio = carbratio_data;
  89. inputs.temptargets = temptargets_data;
  90. inputs.model = model_data;
  91. inputs.autotune = autotune_data;
  92. inputs.clock = clock;
  93. if (autotune_data) {
  94. if (autotune_data.basalprofile) { inputs.basals = autotune_data.basalprofile; }
  95. if (!trioData.onlyAutotuneBasals) {
  96. if (autotune_data.isfProfile) { inputs.isf = autotune_data.isfProfile; }
  97. if (autotune_data.carb_ratio) { inputs.carbratio.schedule[0].ratio = autotune_data.carb_ratio; }
  98. }
  99. }
  100. return trio_profile(inputs);
  101. }