-
Notifications
You must be signed in to change notification settings - Fork 34
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Uncertainty Produced for Duration Operation Involving Days Granularity #325
Comments
Hi @JSRankins and @brynrhodes. As you've noted, the data you've provided contains an interval with date/times that don't specify milliseconds. 5.5.5 Date and Time Intervals indicates that this should result in an uncertainty:
In your example, the imprecise Is there somewhere in the specification that indicates that duration calculations should ignore milliseconds in this case? |
@cmoesel , I think I understand what you are saying given the examples that are located in Appendix H: https://cql.hl7.org/15-h-timeintervalcalculations.html. It's possible within the range of possible milliseconds that the low and high together make the duration less than a whole day. The milliseconds are necessary for datetime calculation when the datetimes by themselves cannot be used to determine if a whole day has occurred. Since @DrMuir raised the concern based on what he was seeing, I'm copying here. @brynrhodes was previously included. @DrMuir @brynrhodes Any questions? |
It's not that the calculation should ignore milliseconds, but rather that for the purposes of comparison, seconds and milliseconds are treated as a single precision represented as a decimal. This behavior is introduced in FHIRPath and discussed in the CQL specification in Comparing Dates and Times as well as in all the comparison operator descriptions, so I was thinking it would apply in determining duration as in this case. I think that could be interpreted either way though, since we are not explicit about it in the duration discussion. But also note that all the examples in the timing interval appendix use times specified to the second and are shown as giving integer results, not uncertainties. Thoughts? |
Thank you for the feedback @brynrhodes. If this is supposed to be based on FHIRPath, then looking at FHIRPath, it is clear that
That leads me to the belief that the engine should calculate using millisecond as 0 (instead of unknown) when seconds are provided and milliseconds aren't. This would resolve the issue. @cmoesel, thoughts? |
Just following up on this. @cmoesel, how do you want to proceed? |
Hi All
Stan, I agree with your statement:
That leads me to the belief that the engine should calculate using millisecond as 0 (instead of unknown) when seconds are provided, and milliseconds aren't. This would resolve the issue. @cmoesel<https://github.com/cmoesel>, thoughts?
Additional thoughts from the peanut gallery ...
Potential additional complexity in dealing with duration of an interval.
Consider midnight to midnight, 24 hours exactly, with both as 00:00.0 for minutes:seconds.milliseconds
From my miliary days, 24:00 was used for midnight rather than 00:00.
In QDM, the interval would be 00:00 to 23:59 so that ***@***.***:00:00.0 is the start of the day and adding 24 hours turns to ***@***.***:00:00.0
Does this imply start of interval assessed as low and end of interval as high if 0 milliseconds at both ends?
Also, is there anywhere in the process where milliseconds might get inadvertently added to test case data from Bonnie to MADiE QDM? (eg current time used as suggested entry in test case?)
Thank you for your wisdom(s)
Peter Muir | MD ABFM FCFP Informatics
ESAC, now proudly part of ICF
Note new email: ***@***.******@***.***>
icf.com<https://www.icf.com/>
…________________________________
From: JSRankins ***@***.***>
Sent: Friday, September 27, 2024 3:37 PM
To: cqframework/cql-execution ***@***.***>
Cc: Muir, Peter (CNTR) ***@***.***>; Mention ***@***.***>
Subject: Re: [cqframework/cql-execution] Uncertainty Produced for Duration Operation Involving Days Granularity (Issue #325)
Just following up on this. @cmoesel<https://github.com/cmoesel>, how do you want to proceed?
—
Reply to this email directly, view it on GitHub<#325 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AJBBZR5Y7F6E2K3F6QF5Y63ZYWXZHAVCNFSM6AAAAABOOVUQ7KVHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDGNZZHEZTKNZZGA>.
You are receiving this because you were mentioned.Message ID: ***@***.***>
|
We still hold that the spec, as written, does not indicate that seconds and milliseconds should be combined for durations. It is clearly specified for comparisons, but calculating duration is not a comparison operator, so comparison semantics do not automatically apply. That said, based on conversation with @brynrhodes, I understand that the intent was for those same semantics to apply to duration, even if it was not clearly stated as such in the spec. But I think that Bryn also agreed that the specification fell short of specifying that clearly for durations. Given that several here seem to agree that the desired behavior is for the seconds and milliseconds to be combined for duration calculations (like it is for comparisons), we would suggest that someone (@brynrhodes?) file a Jira issue to flag this as a technical correction and target a corresponding clarification for the upcoming CQL Errata release. Bryn can then bring this to the HL7 CDS Work Group for a vote to formalize agreement on the behavior. Once the CDS WG has voted to make this change to the spec in the Errata release, we can consider updating the JS engine to support it on time for the Errata publication. |
Thank you @cmoesel for your thorough analysis and response. @brynrhodes, do you want to submit the HL7 JIRA ticket to CQL? For now, I will update the fqm-execution ticket (Issue 312) to reflect status of this ticket: on hold for CQL update. |
Thank you @JSRankins and @cmoesel , I've added this tracker here: https://jira.hl7.org/browse/FHIR-48482 As part of putting this together, I did find these paragraphs at the end of the Determining Difference and Duration section:
hours between @2012-01-01T01:00:00 and @2012-01-01T02:00:00.0
Hopefully this helps, I've proposed a resolution for the tracker as well, and it would be ideal if we could discuss this at the CDS WG call tomorrow, though I understand that's pretty short notice :) |
Thanks, @brynrhodes. I reviewed the Jira ticket and added a suggestion in the comments. It looks good to me and I will plan to join the CDS call today. Also, thanks for finding that tidbit in the Language Semantics section of the spec. I must have missed that page when I was looking for guidance. I definitely looked at all the sections in the top-level menu (e.g., Author's Guide, Developer's Guide, ELM, Reference), but I guess I missed some of the "deep cuts"! |
Good afternoon. The MADiE team received a ticket related to uncertainty surfacing in a Measure Observation when a duration operation is invoked: MADIE-2024. It appears to occur when no milliseconds are provided by user during certain circumstances. To simplify things, I have created a small measure, test data sets and ran them through fqm-execution CLI 1.5.0. The data is attached.
In the test measure, the issue revolves around the following definition:
Measure bundle: DMT-v0.0.000-FHIR.json
FHIR test case with milliseconds: DurationIssueMS.json
FHIR test case with no milliseconds: DurationIssueNoMS.json
Using the test with no milliseconds, the following comes back for the definition "duration in days":
Using the test with milliseconds, the following comes back for the definition "duration in days":
Comments from @brynrhodes indicate that the duration calculation should not be producing an uncertainty in this instance. Please advise.
The text was updated successfully, but these errors were encountered: