DaysProgressPlot
Version 1.0.0 (11 ko) par
Naveed Reza Aghamohammadi
This function can be used to plot progress of a specific variable accorss days. use full for showing progress in clincial trials.
%DAYSPROGRESSPLOT Plot subject-level progress across clinical-trial days with optional begin→end wings.
%
% SUMMARY
% General-purpose, subject-level plotting utility for clinical trials that span D ≥ 3 days.
% It lays out three ticks per day (PRE, CENTER, POST) via GenerateDaysTickValues and:
% • If ONLY dayBeginData is given → plots one trace per subject through CENTER ticks.
% • If dayEndData is also provided → plots traces through PRE ticks and draws per-day
% BEGIN→END “wings” on POST ticks. Thick therapy segments and thickened in-day wings
% are supported via thickDayIndex.
% When dayEndData exists, the axis shows all three ticks per day; labels appear on CENTER ticks.
%
% SYNTAX
% DaysProgressPlot(axObject, dayBeginData, dayEndData, thickDayIndex, ...
% verticalXlineIndex, yLabel, xTickLabels, subjectIDs, subjectColors)
%
% INPUTS
% axObject : axes handle; if empty/omitted, a new axes is created.
% dayBeginData : [N×D] (subjects × days), required.
% dayEndData : (optional) [N×D] same shape as begin; if empty ⇒ begin-only mode.
% thickDayIndex : vector of day numbers where BETWEEN-day segments are thickened
% (e.g., [2 3 4] thickens segments 2→3 and 3→4).
% verticalXlineIndex : vector of integers or fractionals marking condition changes:
% • k (integer) → draw at CENTER tick of day k.
% • v∈(k,k+1) → linear interpolation between CENTER(k) and CENTER(k+1).
% yLabel : (optional) string/char, default "Error (m)".
% xTickLabels : (optional) 1×D labels for CENTER ticks; when dayEndData exists,
% PRE/POST ticks are shown but remain unlabeled.
% subjectIDs : (optional) 1×N or N×1 cell/str/numeric; if provided, legend (color↔ID)
% is placed outside, top-right (northoutside, horizontal).
% subjectColors : (optional) [N×3] RGB; if omitted → EquiDistantColorGenerator(N,9742).
%
% OUTPUTS
% (none) – draws into axObject.
%
% DEPENDENCIES
% GenerateDaysTickValues.m
% EquiDistantColorGenerator.m
% PlotDayTrace.m (generalized version provided alongside this function)
%
% EXAMPLE
% % 6 subjects, 9 days; some END wings only on select blocks; therapy on 2..4 and 6..8
% N=6; D=9;
% beginVals = 35*randn(N,D);
% endVals = [nan(N,1), randn(N,3), nan(N,1), randn(N,3), nan(N,1)];
% DaysProgressPlot([], beginVals, endVals, [2:4,6:8], [1.5,4.5,5.5,8.5], ...
% "Value (unit)", {"Baseline","T-1","T-2","T-3","Mid","T-4","T-5","T-6","Post"}, ...
% "E-"+string(1:N), []);
%
% REVISION HISTORY
% • 2025-11-09: Added center/pre/post tick display when END exists; labeled centers only.
% Thickened in-day connectors on thick days (via PlotDayTrace).
%
% Written by Naveed Reza Aghamohammadi
Citation pour cette source
Naveed Reza Aghamohammadi (2025). DaysProgressPlot (https://fr.mathworks.com/matlabcentral/fileexchange/182561-daysprogressplot), MATLAB Central File Exchange. Extrait(e) le .
Compatibilité avec les versions de MATLAB
Créé avec
R2022b
Compatible avec toutes les versions
Plateformes compatibles
Windows macOS LinuxTags
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!Découvrir Live Editor
Créez des scripts avec du code, des résultats et du texte formaté dans un même document exécutable.
| Version | Publié le | Notes de version | |
|---|---|---|---|
| 1.0.0 |
