Class: DashTimelineValidator::Representation
- Inherits:
-
Object
- Object
- DashTimelineValidator::Representation
- Defined in:
- lib/dash_timeline_validator/representation.rb
Class Method Summary collapse
- .process(context, representation, index) ⇒ Object
- .report_edge_timeline_information(context, representation_result, ss) ⇒ Object
Class Method Details
.process(context, representation, index) ⇒ Object
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
# File 'lib/dash_timeline_validator/representation.rb', line 3 def self.process(context, representation, index) representation_result = {} representation_result["name"] = "Representation-#{index}" DashTimelineValidator::Report.fill_report(representation_result, representation, "bandwidth") DashTimelineValidator::Report.fill_report(representation_result, representation, "codecs") DashTimelineValidator::Report.fill_report(representation_result, representation, "presentationTimeOffset", 0, :duration_iso8601_to_i) if representation.respond_to? "SegmentTemplate" segment_template = representation.SegmentTemplate representation_result["SegmentTemplate"] = {} DashTimelineValidator::Report.fill_report_mandatory(representation_result["SegmentTemplate"], segment_template, "timescale", :to_i) DashTimelineValidator::Report.fill_report_mandatory(representation_result["SegmentTemplate"], segment_template, "media") DashTimelineValidator::Report.fill_report(representation_result["SegmentTemplate"], segment_template, "initialization") DashTimelineValidator::Report.fill_report_mandatory(representation_result["SegmentTemplate"], segment_template, "startNumber") if context[:root]["mpd"]["type"].eql? "dynamic" report_edge_timeline_information = report_edge_timeline_information(context, representation_result, segment_template.SegmentTimeline.nodes) representation_result["SegmentTemplate"]["timeline"] = report_edge_timeline_information end if segment_template.respond_to? "SegmentTimeline" DashTimelineValidator::Segment.process({root: context[:root], previous: representation_result["SegmentTemplate"]}, segment_template.SegmentTimeline.nodes) end end representation_result end |
.report_edge_timeline_information(context, representation_result, ss) ⇒ Object
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 |
# File 'lib/dash_timeline_validator/representation.rb', line 33 def self.report_edge_timeline_information(context, representation_result, ss) client_wallclock = context[:root]["client_wallclock"] ast = context[:root]["mpd"]["availabilityStartTime"] timescale = representation_result["SegmentTemplate"]["timescale"] max_duration = ss.map { |s| s[:d].to_i }.max / timescale min_buffer_time = context[:root]["mpd"]["minBufferTime"] suggested_resentation_delay = context[:root]["mpd"]["suggestedPresentationDelay"] default_presentation_delay = [DashTimelineValidator::Options::DEFAULT_PRESENTATION_DELAY, (min_buffer_time * 1.5)].max timeline_delay = suggested_resentation_delay.nil? ? default_presentation_delay : suggested_resentation_delay # suggested streaming edge based on shaka's behavior streaming_edge = client_wallclock - ast - DashTimelineValidator::Options::BUFFERED_SEGMENTS * max_duration - timeline_delay last_segment = ss.last last_available_time = (last_segment[:t].to_i + (last_segment[:d].to_i * last_segment[:r].to_i)) / timescale if streaming_edge > last_available_time report = DashTimelineValidator::Report.report_warn("Live edge is at #{streaming_edge}s but last segment in timeline starts at #{last_available_time}s") else report = DashTimelineValidator::Report.report_info("Live edge is at #{streaming_edge}s and last segment in timeline starts at #{last_available_time}s") end report end |