-
Notifications
You must be signed in to change notification settings - Fork 61
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
Tolerance margin for the sum of MO durations? #2093
Comments
Hello, in the various EPUB3 Media Overlays and DAISY SMIL parsers I implemented over time, the sum of individual durations from the reading order / publication spine (not accounting for the potentially-excluded time from skippable fragments) is compared against the declared metadata total duration. I also like to check the durations computed from the actual SMIL audio clip-begin/end pairs. Often, I observe discrepancies. If I remember correctly, I used a tolerance margin to mitigate rounding errors that can occur at authoring time, as well as in the reading system / validation tool's own code. I think I even went as far as allowing a 1-second margin of error. However note that this is really just developer-oriented information displayed as a console warning. In other words, discovered inconsistencies are not surfaced to the end-user, such as Thorium's "about publication" GUI panel for example. I think it would be useful if EPUBCheck reported warnings for time differences greater than one second, which are unlikely to be the result of compound rounding errors, but rather of authoring / production mistakes. Would it be possible to check metadata durations (i.e. sum of declared individual spine item durations == declared total duration), as well as actual clip-begin/end SMIL pairs? (i.e. sum of audio durations in single SMIL file == declared metadata for individual spine item duration) |
Yeah, that's the question. Theoretically EPUBCheck tries to stick to the spec as close as possible, so I was wondering if this tolerance could be explicitly allowed in the spec.
Currently (latest preview) EPUBCheck checks metadata durations. Looking into the MO document to check that the declared duration matches the clips duration would be doable, although not a priority 😉 Feel free to file it to the EPUBCheck tracker! |
+1 to that. |
If we specify a tolerance, this means the sum MUST be within the tolerance.
…--
Ori Idan CEO Helicon Books
http://www.heliconbooks.com
On Fri, Mar 18, 2022 at 1:18 PM Ivan Herman ***@***.***> wrote:
Yeah, that's the question. Theoretically EPUBCheck tries to stick to the
spec as close as possible, so I was wondering if this tolerance could be
explicitly allowed in the spec.
+1 to that.
—
Reply to this email directly, view it on GitHub
<#2093 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAB43QB2HRQ4ZIT3NQPZTUDVARRCFANCNFSM5RBDTWMQ>
.
Triage notifications on the go with GitHub Mobile for iOS
<https://apps.apple.com/app/apple-store/id1477376905?ct=notification-email&mt=8&pt=524675>
or Android
<https://play.google.com/store/apps/details?id=com.github.android&referrer=utm_campaign%3Dnotification-email%26utm_medium%3Demail%26utm_source%3Dgithub>.
You are receiving this because you are subscribed to this thread.Message
ID: ***@***.***>
|
Why would we need to change to a requirement? If the recommendation becomes, for example:
Then there is no warning whether you exactly match or are within the tolerance. Otherwise, you get a warning that the sum isn't within the expected tolerance, same as before. |
The issue was discussed in a meeting on 2022-03-25 List of resolutions:
View the transcript1. Tolerance margin for the sum of MO durations? (issue epub-specs#2093)See github issue epub-specs#2093. See github pull request epub-specs#2106. Dave Cramer: we say the sum of the duration for each MO document should equal the total duration, but we've never specified a margin or tolerance for this. Avneesh Singh: I think this is not controversial. Ivan Herman: what I learned when I made tests, is that this value which is in the manifest is there to check the data. Ivan Herman: I can't say whether or not that is so, but if it is just for checking purposes, then allowing some rounding error is fine. Zheng Xu (徐征): from what i've implemented, the duration is variable for different players on different platforms. Avneesh Singh: regarding 1 second, i feel this is more than enough. Maximum 50 ms is what i've used in the past. Brady Duga: can epubcheck just tell you the total duration value that should be in the manifest?. Matt Garrish: epubcheck is checking the total time, yes. I guess it could output that value.. GeorgeK: my recollection is that its difficult to calculate some of these things precisely, depending upon the compression that is being used, resulting in it being off by a smidgen in each file.
Zheng Xu (徐征): as a RS I appreciate having the duration values for the whole book, and for each file. Dave Cramer: i'm not hearing an argument against the 1 sec tolerance.
|
Since EPUB 3.3 the spec says:
EPUBCheck checks this, but I was wondering about using a tolerance margin. Should we define any in the spec? Or expect strict equality to the millisecond?
The text was updated successfully, but these errors were encountered: