profile.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  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) {
  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 freeaps = { };
  34. if (trio_data) {
  35. freeaps = trio_data;
  36. }
  37. var model_data = { };
  38. if (model_input) {
  39. model_data = model_input.replace(/"/gi, '');
  40. }
  41. var carbratio_data = { };
  42. if (carbratio_input) {
  43. var errors = [ ];
  44. if (!(carbratio_input.schedule && carbratio_input.schedule[0].start && carbratio_input.schedule[0].ratio)) {
  45. errors.push("Carb ratio data should have an array called schedule with a start and ratio fields.");
  46. }
  47. if (carbratio_input.units !== 'grams' && carbratio_input.units !== 'exchanges') {
  48. errors.push("Carb ratio should have units field set to 'grams' or 'exchanges'.");
  49. }
  50. if (errors.length) {
  51. return { "error" : errors.join(' ') };
  52. }
  53. carbratio_data = carbratio_input;
  54. }
  55. var preferences = { };
  56. if (preferences_input) {
  57. preferences = preferences_input;
  58. if (preferences.curve === "rapid-acting") {
  59. if (preferences.useCustomPeakTime) {
  60. preferences.insulinPeakTime =
  61. Math.max(50, Math.min(preferences.insulinPeakTime, 120));
  62. } else { preferences.insulinPeakTime = 75; }
  63. }
  64. else if (preferences.curve === "ultra-rapid") {
  65. if (preferences.useCustomPeakTime) {
  66. preferences.insulinPeakTime =
  67. Math.max(35, Math.min(preferences.insulinPeakTime, 100));
  68. } else { preferences.insulinPeakTime = 55; }
  69. }
  70. }
  71. var inputs = { };
  72. //add all preferences to the inputs
  73. for (var pref in preferences) {
  74. if (preferences.hasOwnProperty(pref)) {
  75. inputs[pref] = preferences[pref];
  76. }
  77. }
  78. inputs.max_iob = inputs.max_iob || 0;
  79. //set these after to make sure nothing happens if they are also set in preferences
  80. inputs.settings = pumpsettings_data;
  81. inputs.targets = bgtargets_data;
  82. inputs.basals = basalprofile_data;
  83. inputs.isf = isf_data;
  84. inputs.carbratio = carbratio_data;
  85. inputs.temptargets = temptargets_data;
  86. inputs.model = model_data;
  87. inputs.autotune = autotune_data;
  88. if (autotune_data) {
  89. if (autotune_data.basalprofile) { inputs.basals = autotune_data.basalprofile; }
  90. if (!freeaps.onlyAutotuneBasals) {
  91. if (autotune_data.isfProfile) { inputs.isf = autotune_data.isfProfile; }
  92. if (autotune_data.carb_ratio) { inputs.carbratio.schedule[0].ratio = autotune_data.carb_ratio; }
  93. }
  94. }
  95. return trio_profile(inputs);
  96. }