iints-sdk-python35 1.5.12__tar.gz → 1.5.14__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (296) hide show
  1. {iints_sdk_python35-1.5.12/src/iints_sdk_python35.egg-info → iints_sdk_python35-1.5.14}/PKG-INFO +1 -1
  2. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/pyproject.toml +1 -1
  3. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/__init__.py +1 -1
  4. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/clinical_benchmark.py +2 -2
  5. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/explainable_ai.py +46 -0
  6. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/cli/cli.py +300 -0
  7. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/pid_controller.py +10 -2
  8. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/devices/models.py +25 -6
  9. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/patient/__init__.py +3 -1
  10. iints_sdk_python35-1.5.14/src/iints/core/patient/advanced_metabolic_model.py +331 -0
  11. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/patient/bergman_model.py +77 -38
  12. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/patient/patient_factory.py +15 -0
  13. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/simulator.py +20 -8
  14. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/supervisor.py +20 -17
  15. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/realism_validator.py +25 -13
  16. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/__init__.py +36 -1
  17. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/config.py +5 -1
  18. iints_sdk_python35-1.5.14/src/iints/research/glucose_model.py +1604 -0
  19. iints_sdk_python35-1.5.14/src/iints/research/losses.py +190 -0
  20. iints_sdk_python35-1.5.14/src/iints/tools/ai_realism_auditor.py +324 -0
  21. iints_sdk_python35-1.5.14/src/iints/tools/digital_twin_calibrator.py +85 -0
  22. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14/src/iints_sdk_python35.egg-info}/PKG-INFO +1 -1
  23. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints_sdk_python35.egg-info/SOURCES.txt +5 -0
  24. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_bergman.py +2 -2
  25. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_research_workflows.py +67 -0
  26. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_presets_realism.py +1 -1
  27. iints_sdk_python35-1.5.14/tests/test_scientific_fidelity.py +97 -0
  28. iints_sdk_python35-1.5.12/src/iints/research/losses.py +0 -98
  29. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/LICENSE +0 -0
  30. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/LICENSE-MIT-IINTS-LEGACY +0 -0
  31. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/NOTICE +0 -0
  32. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/README.md +0 -0
  33. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/setup.cfg +0 -0
  34. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/__init__.py +0 -0
  35. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/assistant.py +0 -0
  36. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/backends/__init__.py +0 -0
  37. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/backends/base.py +0 -0
  38. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/backends/mistral_api.py +0 -0
  39. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/backends/ollama.py +0 -0
  40. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/cli.py +0 -0
  41. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/mdmp_guard.py +0 -0
  42. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/model_catalog.py +0 -0
  43. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/prepare.py +0 -0
  44. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/ai/prompts.py +0 -0
  45. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/__init__.py +0 -0
  46. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/algorithm_xray.py +0 -0
  47. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/baseline.py +0 -0
  48. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/booth_demo.py +0 -0
  49. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/carelink_workbench.py +0 -0
  50. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/clinical_metrics.py +0 -0
  51. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/clinical_tir_analyzer.py +0 -0
  52. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/diabetes_metrics.py +0 -0
  53. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/edge_efficiency.py +0 -0
  54. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/edge_performance_monitor.py +0 -0
  55. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/eucys_results.py +0 -0
  56. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/evidence_bundle.py +0 -0
  57. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/explainability.py +0 -0
  58. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/hardware_benchmark.py +0 -0
  59. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/metrics.py +0 -0
  60. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/population_report.py +0 -0
  61. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/poster.py +0 -0
  62. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/reporting.py +0 -0
  63. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/run_quality.py +0 -0
  64. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/safety_index.py +0 -0
  65. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/safety_visualizer.py +0 -0
  66. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/sensor_filtering.py +0 -0
  67. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/study_analysis.py +0 -0
  68. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/study_engine.py +0 -0
  69. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/study_experiment.py +0 -0
  70. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/study_poster.py +0 -0
  71. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/study_protocol.py +0 -0
  72. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/analysis/validator.py +0 -0
  73. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/api/__init__.py +0 -0
  74. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/api/base_algorithm.py +0 -0
  75. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/api/registry.py +0 -0
  76. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/api/template_algorithm.py +0 -0
  77. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/assets/iints_logo.png +0 -0
  78. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/cli/__init__.py +0 -0
  79. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/cli/patient_cli.py +0 -0
  80. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/__init__.py +0 -0
  81. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/__init__.py +0 -0
  82. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/battle_runner.py +0 -0
  83. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/clinical_baseline.py +0 -0
  84. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/correction_bolus.py +0 -0
  85. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/discovery.py +0 -0
  86. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/fixed_basal_bolus.py +0 -0
  87. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/hybrid_algorithm.py +0 -0
  88. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/imitation_controller.py +0 -0
  89. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/lstm_algorithm.py +0 -0
  90. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/mock_algorithms.py +0 -0
  91. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/mpc_controller.py +0 -0
  92. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/neural_controller.py +0 -0
  93. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/algorithms/standard_pump_algo.py +0 -0
  94. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/device.py +0 -0
  95. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/device_manager.py +0 -0
  96. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/devices/__init__.py +0 -0
  97. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/digital_twin.py +0 -0
  98. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/patient/hovorka_model.py +0 -0
  99. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/patient/models.py +0 -0
  100. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/patient/profile.py +0 -0
  101. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/physiology_variation.py +0 -0
  102. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/safety/__init__.py +0 -0
  103. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/safety/config.py +0 -0
  104. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/safety/input_validator.py +0 -0
  105. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/safety/supervisor.py +0 -0
  106. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/simulation/__init__.py +0 -0
  107. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/core/simulation/scenario_parser.py +0 -0
  108. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/__init__.py +0 -0
  109. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/adapter.py +0 -0
  110. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/certify.py +0 -0
  111. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/column_mapper.py +0 -0
  112. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/contracts.py +0 -0
  113. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/datasets.json +0 -0
  114. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/demo/__init__.py +0 -0
  115. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/demo/demo_cgm.csv +0 -0
  116. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/evidence.py +0 -0
  117. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/guardians.py +0 -0
  118. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/importer.py +0 -0
  119. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/ingestor.py +0 -0
  120. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/mdmp_visualizer.py +0 -0
  121. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/medtronic_live.py +0 -0
  122. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/nightscout.py +0 -0
  123. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/physiology_residual_profiles.json +0 -0
  124. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/quality_checker.py +0 -0
  125. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/realism_dashboard.py +0 -0
  126. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/realism_governance.py +0 -0
  127. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/realism_reference.py +0 -0
  128. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/realism_references.json +0 -0
  129. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/registry.py +0 -0
  130. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/research_catalog.py +0 -0
  131. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/runner.py +0 -0
  132. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/study_corruption.py +0 -0
  133. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/synthetic_mirror.py +0 -0
  134. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/tidepool.py +0 -0
  135. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/universal_parser.py +0 -0
  136. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/clinic_safe_baseline.yaml +0 -0
  137. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/clinic_safe_hyper_challenge.yaml +0 -0
  138. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/clinic_safe_hypo_prone.yaml +0 -0
  139. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/clinic_safe_midnight.yaml +0 -0
  140. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/clinic_safe_pizza.yaml +0 -0
  141. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/clinic_safe_stress_meal.yaml +0 -0
  142. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/default_patient.yaml +0 -0
  143. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/patient_559_config.yaml +0 -0
  144. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/reference_azt1d_t1d.yaml +0 -0
  145. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/reference_free_living_t1d.yaml +0 -0
  146. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/data/virtual_patients/reference_hupa_ucm_t1d.yaml +0 -0
  147. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/demo_assets.py +0 -0
  148. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/emulation/__init__.py +0 -0
  149. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/emulation/legacy_base.py +0 -0
  150. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/emulation/medtronic_780g.py +0 -0
  151. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/emulation/omnipod_5.py +0 -0
  152. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/emulation/tandem_controliq.py +0 -0
  153. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/highlevel.py +0 -0
  154. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/jetson/__init__.py +0 -0
  155. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/jetson/endurance.py +0 -0
  156. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/jetson/research_pipeline.py +0 -0
  157. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/learning/__init__.py +0 -0
  158. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/learning/autonomous_optimizer.py +0 -0
  159. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/learning/learning_system.py +0 -0
  160. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/__init__.py +0 -0
  161. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/api.py +0 -0
  162. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/daemon.py +0 -0
  163. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/edge_benchmark.py +0 -0
  164. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/edge_ops.py +0 -0
  165. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/fpga.py +0 -0
  166. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/long_study.py +0 -0
  167. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/medtronic_direct.py +0 -0
  168. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/pico_pump.py +0 -0
  169. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/runtime.py +0 -0
  170. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/service_export.py +0 -0
  171. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/live_patient/uno_q.py +0 -0
  172. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/mdmp/__init__.py +0 -0
  173. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/mdmp/backend.py +0 -0
  174. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/mdmp/eu_ai_pact.py +0 -0
  175. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/metrics.py +0 -0
  176. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/population/__init__.py +0 -0
  177. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/population/generator.py +0 -0
  178. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/population/runner.py +0 -0
  179. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/presets/__init__.py +0 -0
  180. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/presets/evidence_sources.yaml +0 -0
  181. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/presets/forecast_calibration_profiles.yaml +0 -0
  182. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/presets/golden_benchmark.yaml +0 -0
  183. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/presets/presets.json +0 -0
  184. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/presets/safety_contract_default.yaml +0 -0
  185. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/presets/validation_profiles.yaml +0 -0
  186. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/audit.py +0 -0
  187. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/calibration_gate.py +0 -0
  188. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/control.py +0 -0
  189. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/control_eval.py +0 -0
  190. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/data_blend.py +0 -0
  191. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/dataset.py +0 -0
  192. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/evaluation.py +0 -0
  193. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/forecasting.py +0 -0
  194. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/local_ai.py +0 -0
  195. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/local_ai_gate.py +0 -0
  196. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/metrics.py +0 -0
  197. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/model_registry.py +0 -0
  198. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/neural_control.py +0 -0
  199. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/predictor.py +0 -0
  200. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/research/results_manager.py +0 -0
  201. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/scenarios/__init__.py +0 -0
  202. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/scenarios/generator.py +0 -0
  203. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/scenarios/study_pack.py +0 -0
  204. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/__init__.py +0 -0
  205. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/default_algorithm.py +0 -0
  206. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/demos/__init__.py +0 -0
  207. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/demos/live_stage_demo.py +0 -0
  208. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/pico_pump/README.md +0 -0
  209. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/pico_pump/code.py +0 -0
  210. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/pico_pump/serial_protocol.txt +0 -0
  211. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/scenarios/__init__.py +0 -0
  212. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/scenarios/chaos_insulin_stacking.json +0 -0
  213. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/scenarios/chaos_runaway_ai.json +0 -0
  214. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/scenarios/example_scenario.json +0 -0
  215. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/scenarios/exercise_stress.json +0 -0
  216. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/uno_q/README.md +0 -0
  217. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/templates/uno_q/iints_supervisor_bridge.ino +0 -0
  218. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/utils/__init__.py +0 -0
  219. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/utils/csv_safety.py +0 -0
  220. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/utils/plotting.py +0 -0
  221. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/utils/run_io.py +0 -0
  222. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/utils/url_safety.py +0 -0
  223. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/validation/__init__.py +0 -0
  224. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/validation/golden.py +0 -0
  225. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/validation/replay.py +0 -0
  226. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/validation/run_doctor.py +0 -0
  227. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/validation/run_validation.py +0 -0
  228. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/validation/safety_contract.py +0 -0
  229. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/validation/schemas.py +0 -0
  230. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/visualization/__init__.py +0 -0
  231. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/visualization/cockpit.py +0 -0
  232. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints/visualization/uncertainty_cloud.py +0 -0
  233. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints_sdk_python35.egg-info/dependency_links.txt +0 -0
  234. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints_sdk_python35.egg-info/entry_points.txt +0 -0
  235. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints_sdk_python35.egg-info/requires.txt +0 -0
  236. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/iints_sdk_python35.egg-info/top_level.txt +0 -0
  237. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_ai/__init__.py +0 -0
  238. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_ai/lineage.py +0 -0
  239. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/__init__.py +0 -0
  240. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/audit.py +0 -0
  241. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/bias_hooks.py +0 -0
  242. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/bundle.py +0 -0
  243. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/certification.py +0 -0
  244. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/cli.py +0 -0
  245. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/compare.py +0 -0
  246. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/conformance.py +0 -0
  247. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/contracts.py +0 -0
  248. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/crypto.py +0 -0
  249. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/data/conformance/vectors/delegation.json +0 -0
  250. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/data/conformance/vectors/fingerprint.json +0 -0
  251. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/data/conformance/vectors/grading.json +0 -0
  252. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/data/conformance/vectors/signing.json +0 -0
  253. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/delegate.py +0 -0
  254. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/diffing.py +0 -0
  255. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/drift.py +0 -0
  256. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/exceptions.py +0 -0
  257. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/fingerprint.py +0 -0
  258. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/fingerprint_store.py +0 -0
  259. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/hf.py +0 -0
  260. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/keys/mdmp_pub_v1.pem +0 -0
  261. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/llm_provenance.py +0 -0
  262. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/migrate.py +0 -0
  263. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/policy.py +0 -0
  264. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/prov.py +0 -0
  265. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/registry.py +0 -0
  266. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/runner.py +0 -0
  267. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/schema_export.py +0 -0
  268. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/synthetic.py +0 -0
  269. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/trust.py +0 -0
  270. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_core/visualizer.py +0 -0
  271. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_flavors/__init__.py +0 -0
  272. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_integrations/__init__.py +0 -0
  273. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_integrations/dvc.py +0 -0
  274. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_integrations/mlflow.py +0 -0
  275. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/src/mdmp_integrations/wandb.py +0 -0
  276. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_ci_governance.py +0 -0
  277. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_algorithm_loading.py +0 -0
  278. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_booth_demo.py +0 -0
  279. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_carelink_workbench.py +0 -0
  280. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_cloud_import_security.py +0 -0
  281. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_demo_export.py +0 -0
  282. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_demo_live.py +0 -0
  283. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_edge_runtime.py +0 -0
  284. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_expo_tools.py +0 -0
  285. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_fpga.py +0 -0
  286. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_onboarding.py +0 -0
  287. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_patient_runtime.py +0 -0
  288. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_poster.py +0 -0
  289. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_cli_run_summary.py +0 -0
  290. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_install_doctor.py +0 -0
  291. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_jetson_endurance.py +0 -0
  292. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_physiology_variation.py +0 -0
  293. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_plugin_system.py +0 -0
  294. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_population.py +0 -0
  295. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_research_realism_tools.py +0 -0
  296. {iints_sdk_python35-1.5.12 → iints_sdk_python35-1.5.14}/tests/test_simulator_calibration.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: iints-sdk-python35
3
- Version: 1.5.12
3
+ Version: 1.5.14
4
4
  Summary: A pre-clinical Edge-AI SDK for diabetes management validation.
5
5
  Author-email: Rune Bobbaers <rune.bobbaers@gmail.com>
6
6
  License-Expression: Apache-2.0
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
4
4
 
5
5
  [project]
6
6
  name = "iints-sdk-python35"
7
- version = "1.5.12"
7
+ version = "1.5.14"
8
8
  authors = [
9
9
  { name="Rune Bobbaers", email="rune.bobbaers@gmail.com" },
10
10
  ]
@@ -11,7 +11,7 @@ except ImportError: # pragma: no cover - Python < 3.8 fallback
11
11
  try:
12
12
  __version__ = version("iints-sdk-python35")
13
13
  except PackageNotFoundError: # pragma: no cover - source tree fallback
14
- __version__ = "1.5.12"
14
+ __version__ = "1.5.14"
15
15
 
16
16
  # Note to developers: this SDK is currently maintained by a single author.
17
17
  # Please report bugs via GitHub issues and feel free to contribute fixes via PRs.
@@ -14,7 +14,7 @@ from rich.panel import Panel
14
14
  from rich.progress import Progress, SpinnerColumn, TextColumn
15
15
 
16
16
  # Add project root to path
17
- project_root = Path(__file__).parent.parent.parent
17
+ project_root = Path(__file__).parent.parent.parent.parent
18
18
  sys.path.insert(0, str(project_root))
19
19
 
20
20
  from iints.data.adapter import DataAdapter
@@ -81,7 +81,7 @@ class ClinicalBenchmark:
81
81
  """Display benchmark results in formatted table with visualization"""
82
82
 
83
83
  # Import visualization tools
84
- from tools.glucose_visualizer import GlucoseVisualizer
84
+ from tools.analysis.glucose_visualizer import GlucoseVisualizer
85
85
  viz = GlucoseVisualizer()
86
86
 
87
87
  # Show patient overview first
@@ -9,13 +9,59 @@ from datetime import datetime, timedelta
9
9
  from pathlib import Path
10
10
  import numpy as np
11
11
 
12
+ # Import the local Ollama backend
13
+ from iints.ai.backends.ollama import OllamaBackend
14
+
12
15
  class ClinicalAuditTrail:
13
16
  """Explainable AI system for clinical decision transparency"""
14
17
 
15
18
  def __init__(self):
16
19
  self.audit_log = []
17
20
  self.decision_context = {}
21
+ self.ollama = None
22
+
23
+ def _init_ollama(self):
24
+ if self.ollama is None:
25
+ self.ollama = OllamaBackend()
26
+ try:
27
+ self.ollama.ensure_model_ready()
28
+ except Exception as e:
29
+ print(f"Warning: Local AI not available: {e}")
30
+
31
+ def generate_ollama_insight(self, times, glucose, ffa, ketones, insulin):
32
+ """
33
+ Sends the raw physiological arrays to the local Mistral LLM via Ollama
34
+ for an Explainable AI clinical diagnosis.
35
+ """
36
+ self._init_ollama()
37
+ if not self.ollama or not self.ollama.available():
38
+ return "ERROR: Local Ollama AI is not running or available."
39
+
40
+ # Format the data arrays for the LLM
41
+ data_summary = (
42
+ f"Time (min): {times[-5:]}\n"
43
+ f"Glucose (mg/dL): {[round(g, 1) for g in glucose[-5:]]}\n"
44
+ f"Insulin (U): {[round(i, 2) for i in insulin[-5:]]}\n"
45
+ f"FFA (mmol/L): {[round(f, 2) for f in ffa[-5:]]}\n"
46
+ f"Ketones (mmol/L): {[round(k, 2) for k in ketones[-5:]]}\n"
47
+ )
18
48
 
49
+ system_prompt = (
50
+ "You are an Explainable AI for a Type 1 Diabetes Digital Twin. "
51
+ "You analyze raw mathematical arrays from the simulation and provide a clinical explanation. "
52
+ "Explain what the math is doing to the patient. If insulin is 0, mention hepatic glucose production. "
53
+ "If FFA and Ketones are rising, diagnose the lipotoxicity and Diabetic Ketoacidosis (DKA). "
54
+ "Keep the response professional, clinical, and under 4 sentences."
55
+ )
56
+
57
+ user_prompt = f"Analyze the following patient state from the last 25 minutes of the simulation:\n{data_summary}"
58
+
59
+ try:
60
+ response = self.ollama.complete(system_prompt=system_prompt, user_prompt=user_prompt)
61
+ return response
62
+ except Exception as e:
63
+ return f"AI Generation Failed: {e}"
64
+
19
65
  def log_decision(self, timestamp, glucose_current, glucose_trend, insulin_decision,
20
66
  algorithm_confidence, safety_override=False, context=None):
21
67
  """Log AI decision with clinical reasoning"""
@@ -8501,6 +8501,10 @@ def sources(
8501
8501
 
8502
8502
  research_app = typer.Typer(help="Research pipeline: dataset preparation and quality reporting.")
8503
8503
  app.add_typer(research_app, name="research")
8504
+ glucose_model_app = typer.Typer(
8505
+ help="Dedicated glucose forecasting model workflow for training and Hugging Face export."
8506
+ )
8507
+ research_app.add_typer(glucose_model_app, name="glucose-model")
8504
8508
 
8505
8509
 
8506
8510
  @research_app.command(name="prepare-azt1d")
@@ -9602,6 +9606,302 @@ def research_forecast_run(
9602
9606
  )
9603
9607
 
9604
9608
 
9609
+ @glucose_model_app.command(name="build-dataset")
9610
+ def research_glucose_model_build_dataset(
9611
+ input_paths: Annotated[
9612
+ List[Path],
9613
+ typer.Option(
9614
+ "--input",
9615
+ "-i",
9616
+ help="Prepared glucose dataset CSV/Parquet. Repeat for Ohio, AZT1D, simulator exports, etc.",
9617
+ ),
9618
+ ],
9619
+ output_dir: Annotated[
9620
+ Path,
9621
+ typer.Option(help="Output folder for normalized training dataset, manifest, and config."),
9622
+ ] = Path("models/iints-glucose-forecast-v0/dataset"),
9623
+ labels_csv: Annotated[
9624
+ Optional[str],
9625
+ typer.Option(
9626
+ "--labels",
9627
+ help="Optional comma-separated labels matching --input order, e.g. ohio_train,sim_10k.",
9628
+ ),
9629
+ ] = None,
9630
+ profile: Annotated[str, typer.Option(help="Training profile: smoke, quick, long, or paper.")] = "long",
9631
+ output_format: Annotated[str, typer.Option(help="Dataset output format: csv or parquet.")] = "csv",
9632
+ history_minutes: Annotated[int, typer.Option(help="Model history window in minutes.")] = 360,
9633
+ horizon_minutes: Annotated[int, typer.Option(help="Prediction horizon in minutes.")] = 120,
9634
+ time_step_minutes: Annotated[int, typer.Option(help="Expected CGM sample interval in minutes.")] = 5,
9635
+ ) -> None:
9636
+ """Build the dedicated IINTS glucose-forecast training pack."""
9637
+ console = Console()
9638
+ labels = None
9639
+ if labels_csv:
9640
+ labels = [item.strip() for item in labels_csv.split(",") if item.strip()]
9641
+ try:
9642
+ from iints.research.glucose_model import build_glucose_training_pack
9643
+
9644
+ pack = build_glucose_training_pack(
9645
+ input_paths,
9646
+ output_dir,
9647
+ labels=labels,
9648
+ output_format=output_format,
9649
+ profile=profile,
9650
+ history_minutes=history_minutes,
9651
+ horizon_minutes=horizon_minutes,
9652
+ time_step_minutes=time_step_minutes,
9653
+ )
9654
+ except Exception as exc:
9655
+ console.print(f"[bold red]glucose-model build-dataset failed:[/bold red] {exc}")
9656
+ raise typer.Exit(code=1)
9657
+
9658
+ table = Table(title="IINTS Glucose Model Training Pack")
9659
+ table.add_column("Artifact", style="cyan")
9660
+ table.add_column("Value", overflow="fold")
9661
+ table.add_row("Rows", str(pack.row_count))
9662
+ table.add_row("Subjects", str(pack.subject_count))
9663
+ table.add_row("Sources", str(pack.source_count))
9664
+ table.add_row("Dataset", str(pack.dataset_path))
9665
+ table.add_row("Config", str(pack.config_path))
9666
+ table.add_row("Manifest", str(pack.manifest_path))
9667
+ table.add_row("Intent", str(pack.model_intent_path))
9668
+ console.print(table)
9669
+ console.print(
9670
+ "[green]Next:[/green] "
9671
+ f"iints research glucose-model train --data {pack.dataset_path} "
9672
+ f"--config {pack.config_path} --output-dir models/iints-glucose-forecast-v0"
9673
+ )
9674
+
9675
+
9676
+ @glucose_model_app.command(name="init")
9677
+ def research_glucose_model_init(
9678
+ output_dir: Annotated[Path, typer.Option(help="Output directory for the glucose model starter files.")] = Path(
9679
+ "models/iints-glucose-forecast-v0"
9680
+ ),
9681
+ profile: Annotated[str, typer.Option(help="Training profile: smoke, quick, long, or paper.")] = "long",
9682
+ history_minutes: Annotated[int, typer.Option(help="Model history window in minutes.")] = 360,
9683
+ horizon_minutes: Annotated[int, typer.Option(help="Prediction horizon in minutes.")] = 120,
9684
+ time_step_minutes: Annotated[int, typer.Option(help="Expected CGM sample interval in minutes.")] = 5,
9685
+ ) -> None:
9686
+ """Create a glucose-model config and intent file without touching data."""
9687
+ console = Console()
9688
+ try:
9689
+ from iints.research.glucose_model import _render_model_intent, write_glucose_model_config
9690
+
9691
+ output_dir.mkdir(parents=True, exist_ok=True)
9692
+ config_path = output_dir / "glucose_model_config.yaml"
9693
+ payload = write_glucose_model_config(
9694
+ config_path,
9695
+ profile=profile,
9696
+ history_minutes=history_minutes,
9697
+ horizon_minutes=horizon_minutes,
9698
+ time_step_minutes=time_step_minutes,
9699
+ )
9700
+ intent_payload = {
9701
+ "row_count": "pending",
9702
+ "subject_count": "pending",
9703
+ "source_count": "pending",
9704
+ "history_minutes": history_minutes,
9705
+ "horizon_minutes": horizon_minutes,
9706
+ }
9707
+ intent_path = output_dir / "MODEL_INTENT.md"
9708
+ intent_path.write_text(_render_model_intent(intent_payload))
9709
+ except Exception as exc:
9710
+ console.print(f"[bold red]glucose-model init failed:[/bold red] {exc}")
9711
+ raise typer.Exit(code=1)
9712
+
9713
+ console.print(f"[green]Config written:[/green] {config_path}")
9714
+ console.print(f"[green]Intent written:[/green] {intent_path}")
9715
+ console.print(f"Profile: {payload['iints_glucose_model']['profile']}")
9716
+
9717
+
9718
+ @glucose_model_app.command(name="train")
9719
+ def research_glucose_model_train(
9720
+ data: Annotated[Path, typer.Option(help="Normalized glucose training dataset CSV/Parquet.")],
9721
+ output_dir: Annotated[Path, typer.Option(help="Output directory for predictor.pt and training_report.json.")] = Path(
9722
+ "models/iints-glucose-forecast-v0"
9723
+ ),
9724
+ config: Annotated[Optional[Path], typer.Option(help="Config YAML. If omitted, one is generated.")] = None,
9725
+ profile: Annotated[str, typer.Option(help="Generated config profile: smoke, quick, long, or paper.")] = "long",
9726
+ epochs: Annotated[Optional[int], typer.Option(help="Override training.epochs for long local runs.")] = None,
9727
+ batch_size: Annotated[Optional[int], typer.Option(help="Override training.batch_size.")] = None,
9728
+ learning_rate: Annotated[Optional[float], typer.Option(help="Override training.learning_rate.")] = None,
9729
+ warm_start: Annotated[Optional[Path], typer.Option(help="Optional predictor.pt warm-start checkpoint.")] = None,
9730
+ export_hf: Annotated[
9731
+ bool,
9732
+ typer.Option("--export-hf/--no-export-hf", help="Build a Hugging Face-ready folder after training."),
9733
+ ] = True,
9734
+ repo_id: Annotated[Optional[str], typer.Option(help="Optional Hugging Face repo id for model card hints.")] = None,
9735
+ dataset_manifest: Annotated[Optional[Path], typer.Option(help="Optional dataset manifest for HF public metadata.")] = None,
9736
+ comparison_dir: Annotated[
9737
+ Optional[Path],
9738
+ typer.Option(help="Optional glucose-model compare output directory to bundle with the Hugging Face export."),
9739
+ ] = None,
9740
+ ) -> None:
9741
+ """Train the dedicated IINTS glucose-forecast model using the existing predictor engine."""
9742
+ console = Console()
9743
+ if not data.exists():
9744
+ console.print(f"[bold red]Dataset not found: {data}[/bold red]")
9745
+ raise typer.Exit(code=1)
9746
+
9747
+ try:
9748
+ from iints.research.glucose_model import write_glucose_model_config, write_huggingface_export_bundle
9749
+
9750
+ output_dir.mkdir(parents=True, exist_ok=True)
9751
+ resolved_config = output_dir / "glucose_model_config.resolved.yaml"
9752
+ if config is None:
9753
+ payload = write_glucose_model_config(output_dir / "glucose_model_config.yaml", profile=profile)
9754
+ else:
9755
+ payload = yaml.safe_load(config.read_text())
9756
+ if epochs is not None:
9757
+ payload.setdefault("training", {})["epochs"] = int(epochs)
9758
+ if batch_size is not None:
9759
+ payload.setdefault("training", {})["batch_size"] = int(batch_size)
9760
+ if learning_rate is not None:
9761
+ payload.setdefault("training", {})["learning_rate"] = float(learning_rate)
9762
+ resolved_config.write_text(yaml.safe_dump(payload, sort_keys=False))
9763
+
9764
+ script = Path(__file__).resolve().parents[3] / "research" / "train_predictor.py"
9765
+ cmd = [
9766
+ sys.executable,
9767
+ str(script),
9768
+ "--data",
9769
+ str(data),
9770
+ "--config",
9771
+ str(resolved_config),
9772
+ "--out",
9773
+ str(output_dir),
9774
+ ]
9775
+ if warm_start is not None:
9776
+ cmd.extend(["--warm-start", str(warm_start)])
9777
+ subprocess.run(cmd, check=True)
9778
+ hf_outputs = None
9779
+ if export_hf:
9780
+ manifest = dataset_manifest
9781
+ if manifest is None:
9782
+ candidate = data.parent / "glucose_dataset_manifest.json"
9783
+ manifest = candidate if candidate.exists() else None
9784
+ hf_outputs = write_huggingface_export_bundle(
9785
+ model_dir=output_dir,
9786
+ output_dir=output_dir / "huggingface",
9787
+ repo_id=repo_id,
9788
+ dataset_manifest=manifest,
9789
+ comparison_dir=comparison_dir,
9790
+ )
9791
+ except subprocess.CalledProcessError as exc:
9792
+ console.print(f"[bold red]glucose-model train failed with exit code {exc.returncode}[/bold red]")
9793
+ raise typer.Exit(code=exc.returncode)
9794
+ except Exception as exc:
9795
+ console.print(f"[bold red]glucose-model train failed:[/bold red] {exc}")
9796
+ raise typer.Exit(code=1)
9797
+
9798
+ console.print(f"[green]Model written:[/green] {output_dir / 'predictor.pt'}")
9799
+ console.print(f"[green]Training report:[/green] {output_dir / 'training_report.json'}")
9800
+ if hf_outputs:
9801
+ console.print(f"[green]Hugging Face bundle:[/green] {hf_outputs['output_dir']}")
9802
+
9803
+
9804
+ @glucose_model_app.command(name="export-hf")
9805
+ def research_glucose_model_export_hf(
9806
+ model_dir: Annotated[Path, typer.Option(help="Directory containing predictor.pt and training_report.json.")] = Path(
9807
+ "models/iints-glucose-forecast-v0"
9808
+ ),
9809
+ output_dir: Annotated[Path, typer.Option(help="Output directory for the Hugging Face-ready bundle.")] = Path(
9810
+ "models/iints-glucose-forecast-v0/huggingface"
9811
+ ),
9812
+ repo_id: Annotated[Optional[str], typer.Option(help="Optional Hugging Face repo id, e.g. user/iints-glucose-forecast-v0.")] = None,
9813
+ dataset_manifest: Annotated[Optional[Path], typer.Option(help="Optional private manifest to redact into public metadata.")] = None,
9814
+ comparison_dir: Annotated[
9815
+ Optional[Path],
9816
+ typer.Option(help="Optional glucose-model compare output directory to include comparison metrics and reports."),
9817
+ ] = None,
9818
+ ) -> None:
9819
+ """Export predictor.pt plus a research-safe Hugging Face model card."""
9820
+ console = Console()
9821
+ try:
9822
+ from iints.research.glucose_model import write_huggingface_export_bundle
9823
+
9824
+ outputs = write_huggingface_export_bundle(
9825
+ model_dir=model_dir,
9826
+ output_dir=output_dir,
9827
+ repo_id=repo_id,
9828
+ dataset_manifest=dataset_manifest,
9829
+ comparison_dir=comparison_dir,
9830
+ )
9831
+ except Exception as exc:
9832
+ console.print(f"[bold red]glucose-model export-hf failed:[/bold red] {exc}")
9833
+ raise typer.Exit(code=1)
9834
+
9835
+ table = Table(title="Hugging Face Export Bundle")
9836
+ table.add_column("Artifact", style="cyan")
9837
+ table.add_column("Path", overflow="fold")
9838
+ for key, value in outputs.items():
9839
+ table.add_row(key, value)
9840
+ console.print(table)
9841
+ console.print("[yellow]Recommended:[/yellow] upload private first, review README.md, then decide whether public is allowed.")
9842
+
9843
+
9844
+ @glucose_model_app.command(name="compare")
9845
+ def research_glucose_model_compare(
9846
+ data: Annotated[Path, typer.Option(help="Normalized glucose dataset CSV/Parquet to evaluate on.")],
9847
+ output_dir: Annotated[Path, typer.Option(help="Output directory for comparison reports.")] = Path(
9848
+ "results/glucose_model_comparison"
9849
+ ),
9850
+ model_specs: Annotated[
9851
+ Optional[List[str]],
9852
+ typer.Option(
9853
+ "--model",
9854
+ "-m",
9855
+ help="Model checkpoint as label=path/to/predictor.pt. Repeat for MSE/Band/PINN models.",
9856
+ ),
9857
+ ] = None,
9858
+ config: Annotated[Optional[Path], typer.Option(help="Comparison config YAML. Defaults to glucose-model quick config.")] = None,
9859
+ include_baselines: Annotated[
9860
+ bool,
9861
+ typer.Option("--include-baselines/--no-baselines", help="Compare transparent LastValue/LinearTrend/Physiology baselines."),
9862
+ ] = True,
9863
+ mc_samples: Annotated[int, typer.Option(help="MC dropout samples for checkpoint uncertainty. Use 0 to disable.")] = 0,
9864
+ max_roc_mgdl_min: Annotated[
9865
+ float,
9866
+ typer.Option(help="Maximum plausible predicted glucose rate-of-change in mg/dL/min."),
9867
+ ] = 10.0,
9868
+ ) -> None:
9869
+ """Compare MSE/Band/PINN glucose models against baselines and physiology gates."""
9870
+ console = Console()
9871
+ try:
9872
+ from iints.research.glucose_model import compare_glucose_models, parse_model_specs
9873
+
9874
+ bundle = compare_glucose_models(
9875
+ data_path=data,
9876
+ output_dir=output_dir,
9877
+ model_specs=parse_model_specs(model_specs or []),
9878
+ config_path=config,
9879
+ include_baselines=include_baselines,
9880
+ mc_samples=mc_samples,
9881
+ max_roc_mgdl_min=max_roc_mgdl_min,
9882
+ )
9883
+ except Exception as exc:
9884
+ console.print(f"[bold red]glucose-model compare failed:[/bold red] {exc}")
9885
+ raise typer.Exit(code=1)
9886
+
9887
+ table = Table(title="IINTS Glucose Model Comparison")
9888
+ table.add_column("Artifact", style="cyan")
9889
+ table.add_column("Path / Value", overflow="fold")
9890
+ table.add_row("Rows", str(bundle.row_count))
9891
+ table.add_row("Models", str(bundle.model_count))
9892
+ table.add_row("Report JSON", str(bundle.report_json))
9893
+ table.add_row("Report Markdown", str(bundle.report_md))
9894
+ table.add_row("Horizon metrics", str(bundle.horizon_metrics_csv))
9895
+ table.add_row("Physiology violations", str(bundle.physiological_violations_csv))
9896
+ table.add_row("Hypo detection", str(bundle.hypo_detection_csv))
9897
+ table.add_row("Model-card metrics", str(bundle.model_card_metrics_json))
9898
+ console.print(table)
9899
+ console.print(
9900
+ "[yellow]Promotion rule:[/yellow] do not promote a model just because MAE improves; "
9901
+ "also inspect missed hypo rate, uncertainty, and physiological violations."
9902
+ )
9903
+
9904
+
9605
9905
  @research_app.command(name="parity-check")
9606
9906
  def research_parity_check(
9607
9907
  model: Annotated[Path, typer.Option(help="Predictor checkpoint (.pt)")],
@@ -40,7 +40,15 @@ class PIDController(InsulinAlgorithm):
40
40
  self._log_reason("Derivative term calculated", "control_parameter", derivative)
41
41
 
42
42
  # Integral term (accumulated error) with anti-windup protection
43
- proposed_integral = max(-self.integral_limit, min(self.integral + error, self.integral_limit))
43
+ # SCIENTIFIC UPGRADE: Pharmacokinetic (PK) Feed-Forward Integration
44
+ # We dynamically drain the integral windup based on the actual Insulin On Board (mass balance).
45
+ pk_feed_forward_inhibition = data.insulin_on_board * 2.0 # Tuning parameter for PK dampening
46
+
47
+ proposed_integral = max(
48
+ -self.integral_limit,
49
+ min(self.integral + error - pk_feed_forward_inhibition, self.integral_limit)
50
+ )
51
+
44
52
  unsaturated_output = (
45
53
  self.kp * error
46
54
  + self.ki * proposed_integral
@@ -56,7 +64,7 @@ class PIDController(InsulinAlgorithm):
56
64
  )
57
65
  else:
58
66
  self.integral = proposed_integral
59
- self._log_reason("Integral term updated", "control_parameter", self.integral)
67
+ self._log_reason(f"Integral term updated (dampened by {pk_feed_forward_inhibition:.2f} due to {data.insulin_on_board:.1f}U IOB)", "control_parameter", self.integral)
60
68
 
61
69
  # PID formula
62
70
  insulin_dose = (self.kp * error +
@@ -22,12 +22,12 @@ class SensorModel:
22
22
 
23
23
  def __init__(
24
24
  self,
25
- noise_std: float = 0.0,
25
+ noise_std: float = 8.5,
26
26
  bias: float = 0.0,
27
- lag_minutes: int = 0,
27
+ lag_minutes: int = 5,
28
28
  isf_tau_minutes: float = 5.0,
29
29
  noise_ar1_phi: float = 0.85,
30
- noise_fbm_hurst: Optional[float] = None,
30
+ noise_fbm_hurst: Optional[float] = 0.78,
31
31
  dropout_prob: float = 0.0,
32
32
  seed: Optional[int] = None,
33
33
  drift_std_per_hour: float = 0.0,
@@ -393,9 +393,28 @@ class PumpModel:
393
393
  reason = f"max_units_per_step {self.max_units_per_step:.2f}"
394
394
 
395
395
  if self.quantization_units:
396
- delivered = round(delivered / self.quantization_units) * self.quantization_units
397
-
398
- if self.delivery_noise_std > 0:
396
+ # SCIENTIFIC UPGRADE: discrete micro-stepper quantization.
397
+ # The pump delivers integer motor steps; optional noise is modeled as
398
+ # missed or extra steps instead of continuous Gaussian dose drift.
399
+ micro_steps = round(delivered / self.quantization_units)
400
+
401
+ if self.delivery_noise_std > 0:
402
+ # Instead of adding Gaussian noise, we simulate physical rotor slip per micro-step.
403
+ slip_prob = min(0.15, self.delivery_noise_std) # Convert abstract std into slip probability
404
+ actual_steps = micro_steps
405
+ for _ in range(int(micro_steps)):
406
+ if float(self._rng.random()) < slip_prob:
407
+ # 70% chance to miss a step (friction/backlash), 30% chance to double-step (momentum)
408
+ if float(self._rng.random()) < 0.7:
409
+ actual_steps -= 1
410
+ else:
411
+ actual_steps += 1
412
+ micro_steps = max(0, actual_steps)
413
+
414
+ delivered = micro_steps * self.quantization_units
415
+ delivered = max(0.0, delivered)
416
+ elif self.delivery_noise_std > 0:
417
+ # Fallback for continuous infusion models without quantization
399
418
  delivered += float(self._rng.normal(0, self.delivery_noise_std))
400
419
  delivered = max(0.0, delivered)
401
420
 
@@ -3,7 +3,9 @@ from .models import PatientModel
3
3
 
4
4
  try:
5
5
  from .bergman_model import BergmanPatientModel
6
+ from .advanced_metabolic_model import AdvancedMetabolicModel
6
7
  except ImportError: # pragma: no cover - scipy may not be installed
7
8
  BergmanPatientModel = None # type: ignore[assignment,misc]
9
+ AdvancedMetabolicModel = None # type: ignore[assignment,misc]
8
10
 
9
- __all__ = ["PatientProfile", "PatientModel", "BergmanPatientModel"]
11
+ __all__ = ["PatientProfile", "PatientModel", "BergmanPatientModel", "AdvancedMetabolicModel"]