The present application generally relates to video production, including but not limited to systems and methods for addressing latency in video production.
Conventionally, production of a high quality video involves the use of sophisticated equipment, including one or more video cameras. Each video camera is skillfully operated by a trained professional. A video camera can acquire imagery containing many points of interest.
Example points of interests may be basketball players, the ball, or a particular person running a marathon. More than one camera may acquire imagery of the points of interest. The multiple cameras may acquire imagery of the same points of interest at the same time from different viewpoints, such as cameras at each end of a basketball game court, or they may acquire imagery of the points of interest at different times, such as cameras positioned along a marathon course. Further, imagery from the one or more video cameras are centrally processed into a video production. However, since the video production process involves multiple processing steps, some of which are sequentially applied, and some of which can be performed in parallel, these can potentially be implemented as distributed or remote production functions.
The present disclosure is directed towards systems and methods for managing video frame rate at a video production site. There may be a plurality of video production sites arranged in a network, each performing its own video production step(s). It may be challenging to integrate or synchronize the various video production steps if there is latency, delay and/or difference in speed of video processing across at least part of the network. This may for example arise from a user temporarily processing video frames at a rate slower than a target video frame rate. Some embodiments of the present systems and methods include monitoring and correction features that not only detect a slowdown or halt in video processing, and initiates a corrective speed-up in the rate of video frames being presented to the user for processing, but also operate to control the rate of increase in the frequency of video frames so that there is a seamless, smooth and/or gradual transition between video frames being presented to the user. In certain embodiments of the present systems and methods, the overall or average rate of video frames processed by the user can be controlled to correspond to the target frame rate, despite the aforementioned latency or delay.
In one aspect, the present disclosure is directed to a method for managing video frame rate at a video production site. The method may include monitoring, by a video editing processor of a first video production site of a plurality of video production sites, an instantaneous rate of video frames processed by a user, the plurality of video production sites configured to contribute various video production functions over a network. The video editing processor may determine an average rate of video frames processed by the user based on instantaneous rates monitored over a plurality of time instances. The video editing processor may detect that the determined average rate of video frames processed by the user has decreased to a level below a predefined output frame rate. A frame rate controller of the first video production site may determine a rate of change of an instantaneous input rate of video frames being presented to the user for processing. The frame rate controller may increase, responsive to the detection, the input rate of video frames being presented to the user for processing, over a period of time such that the determined rate of change of the instantaneous input rate is below a predetermined threshold, to restore the average rate to the predefined output frame rate.
In some embodiments, monitoring the instantaneous rate of video frames processed by a user comprises monitoring video frames received by an output buffer of the first video production site. In certain embodiments, the predetermined threshold is determined according to activity comprised in the video. The predetermined threshold may be determined according to movement of a point of interest in the video. The video editing processor may receive one or more inputs from the user to process the video frames being presented to the user. The video editing processor may receive the one or more inputs from the user for only a subset of the video frames being presented to the user for processing. Each of the inputs may indicate a point of interest (POI) in a corresponding video frame. The POI may be indicative of a region of interest (ROI) for inclusion as a scene in the video.
In certain embodiments, the frame rate controller may temporarily reduce the input rate of video frames being presented to the user for processing, according to an instruction from the user or a reduced level of video processing by the user. The frame rate controller may use an input buffer of the first video production site to control the input rate of video frames being presented to the user for processing. An output buffer of the first video production site may transmit the video processed by the user, to a second video production site for processing. The frame rate controller may decrease the input rate of video frames being presented to the user for processing, when the average rate of video frames processed by the user approaches or reaches the predefined output frame rate.
In another aspect, the present disclosure is directed to a system for managing video frame rate at a video production site. The system may include a video editing processor of a first video production site of a plurality of video production sites configured to contribute various video production functions over a network. The video editing processor may be configured to monitor an instantaneous rate of video frames processed by a user, the plurality of video production sites. The video editing processor may determine an average rate of video frames processed by the user based on instantaneous rates monitored over a plurality of time instances. The video editing processor may detect that the determined average rate of video frames processed by the user has decreased to a level below a predefined output frame rate. A frame rate controller of the first video production site may be configured to determine a rate of change of an instantaneous input rate of video frames being presented to the user for processing. The frame rate controller may increase, responsive to the detection, the input rate of video frames being presented to the user for processing, over a period of time such that the rate of change of the instantaneous input rate is below a predetermined threshold, to restore the average rate to the predefined output frame rate.
In certain embodiments, the video editing processor is configured to monitor an instantaneous rate of video frames processed by a user, by monitoring video frames received by an output buffer of the first video production site. The predetermined threshold may be determined according to activity comprised in the video. The predetermined threshold may be determined according to movement of a point of interest in the video. In some embodiments, the video editing processor is configured to receive one or more inputs from the user to process the video frames being presented to the user. The video editing processor may be configured to receive the one or more inputs from the user for only a subset of the video frames being presented to the user for processing, each of the inputs indicating a point of interest (POI) in a corresponding video frame, the POI indicative of a region of interest (ROI) for inclusion as a scene in the video.
In some embodiments, the frame rate controller is configured to temporarily reduce the input rate of video frames being presented to the user for processing, according to an instruction from the user or a reduced level of video processing by the user. The frame rate controller may be configured to use an input buffer of the first video production site to control the input rate of video frames being presented to the user for processing. An output buffer of the first video production site may be configured to transmit the video frames processed by the user, to a second video production site for processing. The frame rate controller may be configured to decrease the input rate of video frames being presented to the user for processing, when the average rate of video frames processed by the user approaches or reaches the predefined output frame rate.
The foregoing and other objects, aspects, features, and advantages of the present solution will become more apparent and better understood by referring to the following description taken in conjunction with the accompanying drawings, in which:
The features and advantages of the present solution will become more apparent from the detailed description set forth below when taken in conjunction with the drawings, in which like reference characters identify corresponding elements throughout. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements.
A video camera can acquire imagery containing many points of interest. Example points of interests may be basketball players, the ball, or a particular person running a marathon. More than one camera may acquire imagery of the points of interest. The multiple cameras may acquire imagery of the same points of interest at the same time from different viewpoints, such as cameras at each end of a basketball game court, or they may acquire imagery of the points of interest at different times, such as cameras positioned along a marathon course. Various embodiments of systems and methods described herein may be used to perform or facilitate production of a video using various sources of acquired imagery.
In some aspects, this disclosure relates to producing high quality video content in the presence of temporal latency between a remote production station and a local production station, especially in the presence of interactive manual or automatic control of the content. The interactive control may be, for example, control of the portion of the field of view of the imagery being observed by the end user.
In some embodiments, the present system and methods manage the latency using a spatial cache that represents video data with a field of view larger than the portion of the field of video of the imagery being observed by an end user.
In some embodiments the present system and methods also manage the latency using a temporal cache, which in some embodiments is a buffer of images of a particular temporal duration at the local production station. In some embodiments, the length of the buffer delay module is adaptive in response to a measure of latency of the data transmission to the remote production module.
In some embodiments, a reduced representation of the video data content at a data rate that is lower than the data rate being produced by the local production station is transmitted to the remote production station. The reduced data rate representation may be selected in a particular way to minimize the data rate while at the same time maximizing the performance of the remote production module. In some embodiments, the frame rate of the video data content sent to the remote production station is configured to be above a threshold that enables the manual or automatic processing to meet specific required video production quality criteria, in response to events occurring within the video content.
In some aspects, the present system and methods are directed to producing high quality video content in the presence of latency and also interactive manual or automatic control of the content. The interactive control may include, for example, control of the portion of the field of view of the imagery being observed by the end user. The interactive control may be performed by an automatic system, or may be performed by one or more individuals using a joystick or other user interface device. In some embodiments, control of the portion of the field of view of the imagery may be performed using a mechanical method, such as a Pan/Tilt/Zoom mechanism that is known in the art to point a camera in different locations, or an electronic method where a dynamically-selectable region of the imagery is cut-out or selected from a larger region of imagery acquired from a fixed camera, or a combination of both as is described herein. In some embodiments, the imagery being used to control the camera (either manually or using automatic means) may not be the same imagery being observed by the end user.
One aspect of interactive spatial experience may include the response time to a user command to execute a pan, tilt or zoom. This response time is also known as latency. There are several factors that contribute to latency that can include transmission delays, transmission latency due to intermediate buffers (e.g., transmission buffers, processing buffers), command processing delay, and/or view rendering on a display. In some embodiments, the largest contributors to latency are transmission delays and transmission latency due to intermediate buffers. Latency between the automatic or manual control of the viewing region of interest, and the process that selects or cuts-out the region of interest can result in a region of interest that is different to the region of interest the control method select. In cases where the desired region of interest is moving, for example as in a sports event, then this can result in the region of interest missing or following behind the actual action. Manual or automatic control can also result in unnatural camera motion that is too fast, slow or jerky, for instance. In the case of the electronic selection of the imagery, it is possible to request imagery that is outside the imagery available. In addition, the latency involved may change over time and be unpredictable.
In some embodiments, the present system and methods introduce the concept of “spatial caching” and teaches methods to support local execution of control commands to significantly reduce latency by eliminating two prominent latency contributors: transmission delays and transmission latency due to intermediate buffers.
In some embodiments, the present disclosure further provide methods to provide additional advanced view modification controls with reduced latency even if the data source does not support those controls.
In some embodiments, the present disclosure further provides method to provide stabilized synthesized views with significantly reduced latency even if the data source is jittery and unstable.
In some embodiments, the User Device 2 may interact with the Data Source 1 via a communication interface 5. This interface is a bi-directional interface supporting multimedia content transfer from Data Source 1 to the User Device 2, and ROI control messages from the User Device 2 to the Data Source 1. The communication interface is a typical source of latency.
A viewer using pan-tilt control at a future time T2 may request ROI 12. However, due to latency, the user device may continue to receive video corresponding to ROI 11 for additional duration equal to latency. The user display during this latency period may continue to display the video from ROI 11 as it is received. This may have a disadvantage that the viewer gets an impression of slow response of their control, resulting in the ROI lagging behind the desired position. In alternate implementations of user-interaction, the device can spatially warp (spatially geometrically transforms) the received video corresponding to the pan-tilt control command before displaying it to the viewer. This can address the impression of slow response, however, but can have a disadvantage that certain blank/missing areas 15 may appear in the view during the latency period in some embodiments. At the end of the latency period, video corresponding to the requested ROI may arrive and the display area may be fully rendered without any blank/missing areas. Alternate implementations may smoothly transition the incoming video from an outdated ROI 11 towards the requested ROI 12 while waiting for the updated view. In this approach, the blank area is only gradually exposed. This may perceptually reduce the visual impact of blank areas in the display, but the effect may continue to exist.
For illustration purposes only, the various ROIs are shown to be rectangular in shape. In general, the ROIs may correspond to arbitrarily-shaped masks. Further, the ROIs may be generated through computational means, based on request parameters such as camera calibration parameters, pan, tilt and/or zoom.
In some embodiments, a viewer using pan-tilt control at a future time T2 may request ROI 25 of
In some embodiments, a viewer using zoom control at a future time T2 may request ROI 28 of
The availability of “spatial cache” has an added advantage in some embodiments that the user-device does not have to communicate every ROI adjustment request to the data-source. The user-device may need to request only coarse-level adjustments whenever the spatial cache is anticipated to run out. All fine-level adjustments to ROI adjustment request may be handled locally by the user-device using the spatial cache. ROI adjustment requests may require extra processing or dynamic re-configuration at the data source, which may temporarily interrupt data flow, lead to data loss, and/or lead to other data-source-specific performance loss. In some embodiments, by reducing the number of ROI adjustment requests, the performance of data source may improve.
For illustration purposes only, the data source used in the embodiment shown in
As mentioned previously, in some embodiments, it may be desirable to keep the ROI selected for viewing to be contained within the active region of the field of view of the sensor, so that no border effects such as dark or black pixels need to be displayed or otherwise addressed. In some embodiments, this can be done by clipping or limiting the pixel coordinate positions that define the selected ROI so that it is impossible for the ROI to be positioned outside the sensor field of view. However, such clipping or limiting can result in abrupt motion of the ROI over time. For example, the ROI may be moving rapidly towards the edge of the sensor field of view. It has previously been described how filtering of the desired position can prevent abrupt changes in the position of the ROI, but in certain embodiments a major problem is that in order to achieve this then data for the desired ROI input is required not only from the current time instant but also from future time instants. In one embodiment of the present systems and methods, this problem is overcome by temporal buffering of the image data as well as the desired ROI input data, by smoothing the desired ROI inputs as previously described, and by applying the filtered output response to the time-delayed video. The temporal buffering of the data can be achieved by a set of memory buffers each the size of the data set (for example the size of an image), and as new image data is acquired then the last buffer holding data may get overwritten, and then the process repeats such that each buffer may be cycled through over a time period. The number of buffers can control the amount of temporal delay introduced since the image data arrives at a constant frame rate, and data from all buffers excepting the buffer being written into at any moment in time can be accessed for processing or display.
In another embodiment, the length of the delay is reduced by determining when the ROI selected either by the user or as a result of the smoothing processing is predicted to be outside the field of view of the camera. The required length of the delay may be reduced by the following: If it is thought that the smoothness of the position of the selected ROI needs to have a smoothness constant of 2 seconds (which in this context means that the speed of the moving ROI would change from the highest allowed speed to stationary smoothly in 2 seconds), then this means that without prediction the required delay would need to be at least 2 seconds in length. In the case of buffers with a shorter delay, for example 0.5 second, then similar processing can be used to smooth the ROI position but in addition a prediction of the expected ROI position without any further consideration can be computed based on the velocity and acceleration of the virtual position of the ROI. These values can easily be computed by taking the differences between either the desired input ROI positions or the processed output ROI positions. Returning to the example, then with a 0.5 second actual buffer delay the ROI position can be computed 1.5 seconds in advance of the buffer, resulting in a real and predicted time delay of 2 seconds. If the predicted position is within a threshold distance of the edge of the camera field of view then the speed of the virtual camera (that defines the ROI positions) can be slowed immediately and smoothly by reducing the computed ROI motion by a factor.
In a related embodiment, a system for producing high quality video is as follows. Video data from a sensor at a first data rate may be passed through one or more buffers that introduce a time delay as described previously. A reduced representation of the video data at a second data rate that is lower than the first data rate is transmitted to the ROI selection module that may be remotely located, as shown in
The reduced data rate representation may be selected in a particular way to minimize the data rate while at the same time maximizing the performance of the ROI selection module. More specifically, the performance of the ROI selection module would have that the frame rate of the data exceed a threshold that enables the manual or automatic processing to meet a specific required response time of the virtual camera, in response to the events occurring within the content. In some embodiments, an element that controls the frame rate threshold is the application of videography best practices in selecting the ROI in response to the scene content. In some embodiments a primary requirement of videography best practices is that that activity remains within the ROI and therefore visible to an observer. A minimum frame rate therefore needs to be selected to ensure that even with expected change in positions of points of interest over time in response to events in the scene, then the best-practice rule is met. In one example embodiment, a single camera may have a lens with a field of view such that the entire length of a playing field just occupies the entire horizontal field of view of the camera.
In some embodiments, if the maximum speed of activity to be included in the ROI is S fields-of-view per second, and the horizontal width of the ROI is a factor N of the entire field of view of the camera (where N<1), then the number of frames per second required to keep the activity in the field of view may in some embodiments be S/N. The formulation shows that as the speed of the object of interest in the scene increases, then the required frame rate also increases. The formulation also shows that as the ROI size and therefore N get smaller, than the required frame rate also increases since the object of interest leaves the field of view of the ROI faster.
In some embodiments, measurements from videos of basketball games indicate that the maximum speed S of a basketball (e.g., the maximum speed occurs when the ball is thrown) is approximately 0.5 horizontal field-of-views per second measured with respect to the actual camera field of view (the large rectangle in
Examples of methods for implementing reduced representations of the video that reduce the data rate include compression of the video, and subsampling of the video either spatially or temporally. Examples of transmission methods include TCP/IP, the protocol for the transmission of data over the internet. The ROI selection module can process the reduced representation of the video as previously described to define ROI positions as described. These ROI positions are then transmitted to a segmentation module connected to the buffers of the video data, as shown in
In one embodiment, the ROI selection module may be implemented by a GUI whereby a viewer observes the video and the desired position may be chosen manually with repetitive mouse clicks, or by an automatic ball-following algorithm. An example of a ball-following algorithm is the detection of circular objects in the video using a Hough Transform configured for circle detection (U.S. Pat. No. 3,069,654).
In some embodiments, the length of the buffer delay module in
In some other embodiments, the length of the buffer delay module in
In some aspects, this disclosure relates to producing high quality broadcast video content where the production components are distributed across different people and/or geographically.
In one embodiment, the present methods and systems can integrate outputs of a plurality of distributed production components in order to maintain broadcast production quality if one or more production components fails to deliver production material of sufficient quality.
In another embodiment, the present methods and systems can integrate outputs of a plurality of distributed production components such that transitions between use or dis-use of production components produces a seamless produced video output.
In another embodiment, the present methods and systems can cascade distribution production components such that the output of one distributed production component is the input of a second distributed production component still maintaining at the output of the second production component an assessment of production quality that is a function of the first distributed component and the second distributed component.
In another embodiment, the present methods and systems can produce high quality video content where the production components are distributed across different people and/or geographically, and where a first production component is being performed at a video frame rate that is greater than the frame rate of one or more production components, subsequent to an editing step being performed by the first production component.
In another embodiment, the present methods and systems can incorporate or operate with a payments system that automatically reimburses service-providers of distributed production components based on the quality of the produced content from the service-provider's production component.
In some embodiments, the present methods and systems can produce high quality video content where the production components are distributed across different people and/or geographically. The distributed production components may be operated by distributed service providers where management and quality control of the service is uncertain. For example, video production can be performed by skilled professionals managed in a highly-controlled and centralized fashion as a means to ensure quality of video content production. However this can be an expensive means of ensuring quality of production since the labor cost of skilled professionals is high. It is also not a scalable means of ensuring quality of production over very large numbers (e.g., millions) of video feeds distributed widely geographically, at least because large numbers of skilled professionals do not exist, and also because tight management control and quality control of widely distributed operations performed even by skilled professionals is difficult and expensive.
In one embodiment, the present methods and systems can integrate the outputs of a plurality of distributed production components in order to maintain production quality if one or more production components fails to deliver production material of sufficient quality.
In one embodiment, a first step in the process may begin with the control module within the production integration, as shown in
Another step in the process in the embodiment may begin shortly before the event is due to be produced. The control module can compare the current time to the scheduled time of an event in the database, and if the difference in these times is less than a threshold (a preferred time difference is 30 minutes or less) then the control module cam send a signal to the distributed production module using the unique identifier (such as a unique IP address) as a means to direct the signal. In some embodiments, the signal is transmitted to a production process module, which is a sub-module of the distributed production module shown in
A next step in the process flow in the embodiment may correspond to the actual production process. A first component in this step may include transmittance of a representation of the video, typically at a lower resolution than the original video, to the production process module. U.S. Provisional Patent application 62/250,186 describes particular methods by which the Representation Module performs this component. The production process module can perform the production element, such as activity following. For example, an operator may use a joystick to move a cursor to the center of activity in a sports event, so that as a ball moves from one side of a stadium to the other, then the coordinates of the activity is followed. Methods for performing this are also described in U.S. Provisional Patent application 62/250,186. In some embodiments, an important element of the distributed production module is the production quality assessment sub-module shown in
Results of the production quality assessment module and the production process module itself are then transmitted back to the production integration module by means of the production process metadata stream transmission module, and the production quality parameter stream transmission module, also shown in
In some embodiments, a meta-data integration sub-module within the production integration module may ingest the production process metadata streams from a plurality of distributed production process modules, while a quality parameter stream arbitration module ingests the quality assessment streams from the same plurality of distributed production process modules, as shown in
A next step in the process flow may include processing the quality parameter streams. In the meta-data, each video frame associated to each process may have a frame number, and at least one quality metric assigned to it (as shown in rows 2 and 3 of
In some embodiments, the selection may be subject to hysteresis that requires that the selection remains constant for at least a time period (e.g., a preferred value may be 1 minute or less) or at least a particular number of frames (e.g., a preferred value may be 3000 frames or less) regardless of the quality values. This is because a subsequent process—by the metadata integration module—may use data from multiple frames over time to blend or merge the metadata from different production processes (e.g., even of the same type) so that switching the selection between production modules operated by personnel with different performance characteristics does not result in a step response in the produced video output, as shall be described later.
In another embodiment of the arbitration module, selection may be based on a filtered output of some or all of the quality streams. In some embodiments, the filtering may be an outlier rejection method such that, for example, if any of the streams is different from the average of the other streams by more than a threshold, then it is not considered for selection. An example embodiment or configuration of this is shown in
In some embodiments, the results of the quality stream arbitration module are sent to the meta-data integration module as shown in
In some embodiments, an example of a blending algorithm is shown in
In another embodiment, the present systems and methods may cascade distribution production components such that the output of one distributed production component is the input of a second distributed production component, while still maintaining at the output of the second production component an assessment of production quality that is a function of the first distributed component and the second distributed component.
In some embodiments, one important aspect is that the assessment of production quality that is output from a first production module is an algorithmic function of the production quality of all the quality assessments of all the distributed component modules that are inputted to the first production module. An example of such an algorithmic function may comprise: identifying the minimum value of all the values of the quality assessments connected as an input to the production module. In this embodiment, if there is a quality problem with a first production module connected as an input to a second production module such that the quality assessment drops, then the quality of the output of the second production module shall also drop even if the actual process being performed by the second production module is of high quality. This may reflect the fact that the overall production quality may be compromised even if just one of the steps of production is of low quality.
In another embodiment, the present systems and methods may edit the output of a distributed production module to correct for errors in production.
In some embodiments, the present systems and methods may produce high quality video content where the production components are distributed across different people and/or geographically, and where a first production component is being performed at a video frame rate that is greater than the frame rate of one or more production components, subsequent to an editing step being performed by the first production component. A problem being addressed is that when an editing process occurs, a fixed time delay between the input and output data streams is introduced caused by the time it takes for an operator to correct the error. If subsequent errors are made, then the time delays due to errors can accumulate. In this case, eventually the buffer delay module both in the distributed production module and also the video production integration module may not be sufficiently large to accommodate such accumulations in delays. It may also be undesirable to delay the video production. In some embodiments of the present systems and methods, this is resolved by performing the production process in a first distribution module at a video frame rate that is greater than the frame rate of one or more production components, subsequent to an editing step being performed by the first production component. In this way, the time delay gradually can reduce back to zero. In one embodiment, the nominal frame rate is defined as R0. Preferred values of R0 are 15 frames per second for example, in one or more embodiments. The nominal length of the buffer delay module may be L0=15×60×2=1800 frames which corresponds to 2 minutes of data at the nominal frame rate, for example. In some embodiments, the point at which data is being retrieved from the buffer is given by L(t), where t is the moment in time. When no editing has occurred, then L(t)=0, which means that the most recent data is being used for production for example. In an example scenario, when editing that has taken 1 minute has occurred, then L(t)=900 since data is now being accessed from 1 minute before the current time. An example algorithm that increases the frame rate temporarily over time to reduce L(t) back to 0 is: R(t+1)=(R0+K*R(t)*L(t)), where R(t+1) is the new specified frame rate at which the production process is specified to be performed, and R(t) is the previous specified frame rate at which the production process was performed. A preferred example of K in the example embodiment is K=15/(15*900)=0.001111. For example, after an editing step that has taken 1 minute has been completed, then using the algorithm, the new frame rate specified after the error has occurred is R(t+1)=(15+0.00111*15*900)=30 frames per second. This may be twice the nominal frame rate typically used for production and therefore the data being fed out of the buffer delay module may exceed the rate at which data is being ingested into the buffer delay module, so that the value of L(t) (e.g., the location from which data in the buffer delay module is being extracted for production) begins to reduce. As the value of L(t) reduces then the algorithm may gradually reduce the frame rate towards the nominal frame rate R0. In this way multiple successive editing steps can be performed without the accumulation of processing delays.
In another embodiment, the present systems and methods incorporate or operate with a payments system that automatically reimburses providers of distributed production components based on the quality of the produced content from the provider's production component.
The ability to produce broadcast-quality video remotely from an event greatly reduces the cost of deploying personnel and equipment at the site. With remote production, functions that were once done on-site or locally can be performed off-site or remotely so that personnel and equipment can be shared between events, and also without transportation, setup, and tear-down costs for example. Some methods for broadcast-quality remote production have had to use specialized data communication infrastructure between the local and remote locations to minimize to just a few milliseconds the latency or time-delay between the local activity and the remote production functions. Such specialized data communication infrastructures can be expensive and has limited the mass deployment of remote broadcasting.
The present systems and methods are capable of performing broadcast-quality, remote production using standard IP network infrastructure connecting local and remote production functions. This can greatly reduce costs and can enable the deployment of remote production at any event served by a broadband IP network connection. The present systems and methods can address a number of key problems in remote production, including latency and synchronization.
Latency problems can occur due to network delays, such that video data sent remotely is processed at a different time to events that occur locally.
Synchronization problems can occur due to unknown variations in the network latency over time such that video sent remotely cannot be synchronized to video locally. Such variations in latency can happen all the time over standard IP networks due to many factors, including usage by other network users. Thus, broadcast production should have video frames to be delivered synchronously for broadcast at a fixed rate per second precisely without fail, while variations in network latency means that remote production data can only be sent asynchronously at varying time intervals.
Some remote broadcasting methods aim to overcome latency and synchronization barriers by deploying custom and specialized data networks. Embodiments of the present systems and methods address these issues by a unique remote production architecture with specific latency and synchronization processing at both the local and remote locations. This architecture is illustrated in
Embodiments of the present systems and methods can manage latency and synchronization over standard IP networks using a Cloud LIve Processing (CLiP) architecture or system, an embodiment of which is shown in in
The local latency & synchronization processing module can generate a remote video representation that is suitable both for transmission over standard IP networks and for operators to perform remote production functions. The remote video representation can be the result of minimizing video attributes, such as resolution and frame rate, to optimize video transmission over the designated IP network, while at the same time maximizing the ability of remote operators to perform their production functions. For example, a remote ball-following function may typically require a higher frame rate but lower spatial resolution in order to follow rapid changes in activity in the scene, compared to a remote commentary function that typically requires higher resolution imagery but at a lower frame rate to enable the remote operator to identify specific features such as player numbers or identities.
The asynchronous to synchronous conversion module can take remote asynchronous data inputs, such as camera position or graphic overlay data, and generate synchronous data outputs at the same frame rate as the source videos.
Temporal video caching aligns the local broadcast function's real-time temporal output with the remote broadcast function's temporal output, accounting for the latency between the local and remote broadcast functions, using sequential video and data buffers. Latency can vary widely depending on network usage and also the geographic locations of the local production function and the remote production functions, but typically varies between less than 100 msecs to 500 msecs on average. Some embodiments of the present systems and methods can provide temporal video caching that manages this latency adaptively such that the temporal difference between the source and produced video data is minimized for any given IP network connection.
Spatial video caching can account for any spatial differences in the regions of interest selected by remote production functions (e.g., as a result of ball-following functions), and the regions of interest computed by the asynchronous to synchronous conversion and temporal video caching processes.
Producing Synchronous Output with Asynchronous Network Conditions
In some aspects, the present disclosure is directed towards systems and methods for managing video frame rate at a video production site. There may be a plurality of video production sites arranged in a network, each performing its own video production step(s). It may be challenging to integrate or synchronize the various video production steps if there is latency, delay and/or difference in speed of video processing across at least part of the network. This may for example arise from a user temporarily processing video frames at a rate slower than a target video frame rate. For instance, there can be a delay in video frames being produced due to a user error, or the user being temporarily away or unavailable to perform video production tasks. Some embodiments of the present systems and methods include monitoring and correction features that not only detect a slowdown or halt in video processing, and initiates a corrective speed-up in the rate of video frames being presented to the user for processing, but also operate to control the rate of increase in the frequency of video frames so that there is a seamless, smooth and/or gradual transition between video frames being presented to the user, during the “catch-up” process. In certain embodiments of the present systems and methods, the overall or average rate of video frames processed by the user can be controlled to correspond to the target frame rate, despite the aforementioned latency or delay.
In one embodiment, several remote production modules (or video production sites) are distributed and configured depending on their functionality (e.g., ball-following, commentary addition, score addition) to be either serial or parallel, as shown in
One of the remote video production modules is shown in more detail in
In some embodiments, the network connections between the modules, and/or the modules themselves, may have data latencies, and may be asynchronous, such that the available data rate may increase or decrease momentarily. As discussed previously, there is a need however that the integration module output video data at a constant frame rate, indicated in
The above concept similarly applies to the output buffer, so that if the remote production function and/or user produces processed video frames at the target frame rate, and the output buffer outputs the processed video frames at the same target frame rate, then the output buffer does not overflow. If data momentarily does not arrive at the output buffer due to momentary delays or outages of the remote production function and/or user, then the size of data in the output buffer can begin to reduce. However, when delays or outages are no longer an issue, data may then be sent at a higher frame rate than the target frame rate, so as to maintain an overall rate at or close to the target frame rate. This can replenish the output buffer back to the same level.
In one embodiment, the data transmitter module at the output of each remote distributed production module enables video frame rate data to be transmitted faster or slower than a preferred fixed frame rate Fps0, but in a way that ensures that the average frame rate over a given period equals the preferred fixed frame rate. In some embodiments this is accomplished by ensuring that:
Avg(FpsOUT(t))=Fps0
over a time period approximately equal to the size of the output buffer. A preferred value for the size of the output buffer is 5 seconds, for example. Network protocols such as TCP/IP guarantee that data arrives at the next processing module, and this means that any momentary network outage between the output of one distributed production module and the next results in automatic pausing of the data transmission until the network is restored. This is reflected in a delay in the transmission of data, which can be measured and used to measure the instantaneous FpsOUT(t) at any time instant t. Based on the actual measurements of FpsOUT(t) over previous times t−1, t−2, t−3 etc., then the controlled value FpsOUT_y of FpsOUT at the next time instant in some embodiments may be:
FpsOUT_y(t+1)=Fps0+K2×(Fps0−Avg(FpsOUT(t), FpsOUT(t−1), FpsOUT(t−2), FpsOUT(t−3), FpsOUT(t−4), . . . ))
where K2 is a gain factor that controls the rate at which the controlled value of FpsOUT changes over time in response to momentary outages in network connectivity. A preferred value of K2 is 0.1, for instance. In this embodiment, if the average of the measured output frame rate over the previous time is less than Fps0, then the control value of FpsOUT_y(t+1) is set to be greater than Fps0 in order to compensate for the deficiency in data. If the average of the measured output frame rate over the previous time is greater than Fps0, then the control value of FpsOUT_y(t+1) is set to be smaller than Fps0 in order to compensate for the overflow of data.
In another embodiment, the rate control signal for a first remote distribution module at any time t can be defined as Fps1(t). If Fps0 is the preferred frame rate, then in one embodiment, an algorithm for controlling the processing rate may be:
Fps1(t)=Fps0+K*(Avg(FpsIN(t))−Fps0)
where Avg(FpsIN(t)) is the average of the sum of the frame rate input into the module over a period of time corresponding approximately to the size of the input buffer. In some embodiments, a preferred size of the input buffer is 5 seconds, for instance. The value of K is a gain factor that controls the rate at which the control signal changes in response to variations in the data rate of the network.
If K is greater than 0 (a preferred value is 0.1) then if FpsIN(t) falls below Fps0 at any time instant t, then the processing rate Fps1(t) reduces. On the other hand, upon restoration of network connectivity, then FpsIN(t) may increase above the value of Fps0, and the rate of processing may increase above the value of Fps0.
In some embodiments of the present systems and methods, the rate of video frames presented to the operator or user for processing does not have to be constant at the target frame rate. The instantaneous rate of the video frames presented to the operator (e.g., from the input buffer) may be modified subject to constraints that prevent disruption to seamless interaction of the operator with a video production module. For example, sudden changes in the presented frame rate can make it difficult for the operator to predict the location of activity from the video, if the video production being performed is ball-following during a ball game for instance.
In a typical sports event, the camera steadily follows activity, and the operator is used to predicting where the camera should point based on past locations of the activity. However, if the frame rate of the displayed video suddenly changes to twice the frame rate (during a speed-up or catch-up process for instance), then the apparent position of the activity suddenly and unnaturally moves at twice the rate also, making it difficult to use prior locations of activity to predict current locations of activity. In certain embodiments, this is resolved by limiting the rate of change of the rate of video frames being presented to the user. This gives the user a period of time to accommodate a change in frame rate and enables the user to use prior observations of locations of activity to predict future locations.
In some embodiments, there may be a plurality of video production sites, each performing its own video production step(s). These video production sites may be connected to each other in parallel for instance. For example, a first video production site may perform ball-following and a second video production site may perform scoring, as shown in
In one embodiment, this is addressed by the present systems and methods by having a video editing processor determine an average rate of video frames processed by the user based on instantaneous rates monitored over a plurality of time instances. One method of determining the instantaneous rate is to compute 1/(T1−T0), where T1 and T0 are the successive times that successive frames are displayed on a screen to the user. One method of determining an average frame rate is to average the instantaneous rates determined over a time period. The time period may be 1 minute in some embodiments, for example. The video editing processor then detects or determines whether the average rate of video frames processed by the user has decreased to a level below a predefined output frame rate, for example 30 Hz. The average rate of video frames may have dropped or reduced below the preferred or predefined output frame rate due to latencies introduced by corrections or delays added by the user, for example. A frame rate controller, responsive to such detection or difference between the average frame rate and the preferred frame rate, may increase the input rate of video frames being presented to the user for processing, over a period of time such that the rate of change of the instantaneous input rate is below a predetermined threshold. This can restore the average rate to the predefined output frame rate while at the same time prevents disruption to seamless interaction of the operator with a video production module, and avoids sudden changes in the presented rate of frames which would make it difficult for the operator to predict the location of activity from the video, if the video production function being performed is ball-following for example.
In one embodiment, the time period over which seamless interaction of the operator with the video production module is most important is when activity in the video is moving most quickly, which in many sports events is correlated to the duration of time that it takes for a ball to be passed from one player to the next. However, when a ball reaches a player, then discontinuous activity occurs in any case. In some embodiments, a representative or typical duration of time that it takes for a ball to be passed from one player to the next is T seconds. If the initial frame rate is F0, and the later frame rate is F1 then it may be preferred that the rate of change of frame rate is a value less than (F1−F0)/T. In some embodiments, for fast moving sports, T has a preferred value of 0.25 seconds for example. In slower-moving sports, T has a value of 1 second for example.
In certain embodiments, the minimum preferred frame rate presented to the user may also be a function of the time that it takes for a ball to be passed from one player to the next. For example, if the time to pass the ball is T seconds, then showing the user a frame once every 2 T seconds would not yield quality production since much of the movement of activity would be missed or skipped due to signal aliasing (e.g., observations are sub-sampled temporally below the actual temporal movement). This is resolved in some embodiments of the present systems and methods by ensuring that the Nyquist sampling limit is not exceeded such that the maximum time between frames (e.g., that defines the frame rate) presented to the user does not exceed 0.5 T seconds.
Referring now to
Referring to (1201), and in some embodiments, a video editing processor of a first video production site may monitor an instantaneous rate of video frames processed by a user. The first video production site may be one of a plurality of video production sites configured to contribute various video production functions over a network. Certain video production functions may be performed sequentially over a number of video production sites. Other video production functions may be performed in parallel by two or more video production site. A video production site may receive (e.g., via a input buffer) video frames for processing by a user at the video production site. In some embodiments, the video editing processor receives one or more inputs from the user to process the video frames being presented to the user. The user may process the video frames via any type or form of user input, such as via a click on a POI displayed on a video frame, to highlight the POI or to identify a scene around the POI for instance.
In some embodiments, the video editing processor receives input from the user for only a subset of the video frames being presented to the user for processing. Due to the rate at which such video frames are presented to the user for processing, the user may not be able to provide user input for every video frame. Each of the inputs may for instance indicate a point of interest (POI) in a corresponding video frame. The POI may indicate or be used to identify a region of interest (ROI) for inclusion as a scene in the video, for example. Sometimes, the user may cause the rate at which video frames are presented to the user to be reduced, e.g., due to user error, corrective action or additional processing by the user, or non-availability of user to process certain frames or for a period of time. The frame rate controller may temporarily reduce or increase the input rate of video frames being presented to the user for processing, according to an instruction from the user or a reduced or increased level of video processing by the user. Therefore, the instantaneous rate of video frames processed by a user can change from time to time.
In some embodiments, the video editing processor monitors, detects, calculates, tracks, estimates or otherwise determines the instantaneous rate of video frames processed by a user. The video editing processor may for example perform this by monitoring video frames received, tracked and/or reported by an output buffer of the first video production site. For instance, the number and/or rate of video frames received by the output buffer may be detected or tracked via a counter or pointer that is updated responsive to incoming and/or outgoing video frames. The output buffer and/or input buffer may each comprise any type or form of memory or storage device, and may incorporate a queue ad/or a suitable data structure.
Referring to (1203), and in some embodiments, the video editing processor may determine, estimate or calculate an average rate of video frames processed by the user based on instantaneous rates monitored over a plurality of time instances. The video editing processor may track instantaneous rates determined with respect to various points or periods of time. The video editing processor may track the number of video frames processed by the user during various periods of time. The video editing processor may use such information collected or determined (e.g., over a predefined time window) to determine an average rate of video frames processed by the user. The video editing processor may periodically determine an average rate of video frames processed by the user. The video editing processor may dynamically adjust an interval between time instances, or dynamically identify time instances, for determining average rates of video frames processed by the user.
Referring to (1205), and in some embodiments, the video editing processor may detect that the determined average rate of video frames processed by the user has decreased to a level below a predefined output frame rate. The video editing processor may compare the average rate of video frames processed by the user, with a target, preferred and/or predetermined frame rate (e.g., 30 Hz), responsive to the determined average rate of video frames processed by the user. The video editing processor may periodically, or at dynamically determined intervals or time instances, compare the average rate of video frames processed by the user, with a target, preferred and/or predetermined frame rate. The detection that the determined average rate of video frames processed by the user has decreased to a level below a predefined output frame rate may trigger the video editing processor to provide a feedback or signal to a frame rate controller of the first video production site.
Referring to (1207), and in some embodiments, the frame rate controller of the first video production site may determine a rate of change of an instantaneous input rate of video frames being presented to the user for processing. The detection that the determined average rate of video frames processed by the user has decreased to a level below a predefined output frame rate may trigger the frame rate controller to initiate a change in the input rate of video frames being presented to the user for processing, e.g., to restore or maintain the overall/average processing rate or speed at the preferred frame rate. Thus, the instantaneous input rate of video frames being presented to the user for processing would change (e.g., increase, according to a catch-up process). The frame rate controller of the first video production site may determine the rate of change so as to control the rate of change to an acceptable or appropriate level for user review and/or processing of the presented video frames.
Referring to (1209), and in some embodiments, the frame rate controller may increase, responsive to the detection, the input rate of video frames being presented to the user for processing, over a period of time such that the determined rate of change of the instantaneous input rate is below a predetermined threshold, to restore the average rate to the predefined output frame rate. The frame rate controller may limit the rate of change of the instantaneous input rate of video frames being presented to the user for processing, to avoid jarring or abrupt transitions between video frames presented to the user, as discussed earlier. The frame rate controller may limit the rate of change, by changing the instantaneous input rate over a period of time, e.g., according to the type and/or levels of activity or movements inherent in the video. The frame rate controller may limit the rate of change to the predetermined threshold. The predetermined threshold may be determined according to activity comprised in the video. For example, the predetermined threshold may be determined according to movement of a point of interest in the video.
In some embodiments, the frame rate controller may for instance use the input buffer to control the input rate of video frames being presented to the user for processing. For example, the input buffer may be controlled to transmit or provide outbound video frames at a higher rate, from its store of accumulated incoming video frames. The input buffer may be controlled to transmit or provide outbound video frames at a rate higher than the predefined frame rate (e.g., for a period of time), to ensure that the overall/average rate of processing reaches the predefined frame rate. The frame rate controller may decrease the input rate of video frames being presented to the user for processing, when the overall/average rate of video frames processed by the user approaches or reaches the predefined output frame rate. The input buffer may be controlled to provide video frames to the user so that the overall/average rate of processing is substantially maintained at the predefined frame rate. The output buffer may transmit the video frames processed by the user (e.g., at the predefined frame rate), to a second video production site for processing.
In some aspects, the present disclosure is directed towards systems and methods of improving quality in video production. Some embodiments of the present systems and methods may use sparse, aperiodic, intermittent or asynchronous user input specific to only certain image frames, for example, to determine scenes from available image frames to include in a video being produced. Methods and apparatus are described for performing effective automatic or semi-automatic video production using video clips acquired from one or more camera sources over a time period. In some embodiments, different points of interest in the video clips are each the focus of different video productions, each video production comprising different portions of the video clips from the different sources at different time intervals. In some embodiments, the source video clips are processed using methods that generate very high-quality video products.
A video camera can acquire imagery containing many points of interest. Example points of interests may be basketball players, the ball, or a particular person running a marathon. More than one camera may acquire imagery of the points of interest. The multiple cameras may acquire imagery of the same points of interest at the same time from different viewpoints, such as cameras at each end of a basketball game court, or they may acquire imagery of the points of interest at different times, such as cameras positioned along a marathon course. In some applications it is useful to view a point of interest consistently over a time period. For example, for after-action review, a basketball player may only want to view close-up imagery of the player over an entire game in order to assess their performance, and a marathon runner may only want to view video of themselves as they complete the course. Generally, if there are C cameras recording an event and P points of interest at a frame rate of F frames acquired per second, then the number of potential points of interest in the images is C×P×F. In an example, if C is 10, P=20, F=30, then there are 6000 potential observations of points of interest each second. In addition, the final produced video has to be extremely high quality. There is a need therefore for automatic or semi-automatic methods for performing video production.
According to some embodiments, a list of a first type is generated, said list comprising a sequence of records, each record comprising a camera ID, a point-of-interest ID, a temporal position coordinate with respect to recorded time, a spatial position coordinate with respect to the camera image, and a quality of view metric for the point of interest.
According to some embodiments, a means is provided for performing a search through one or more lists of the first type to identify and group records with the same point of interest ID from the one or more lists of the first type, to generate a plurality of lists of a second type wherein each list of the second type comprises records where the point-of-interest ID is the same.
According to some embodiments, a means is provided for sorting the records in each of one or more lists of the second type with respect to the temporal position coordinate to generate a plurality of lists of a third type.
According to some embodiments, for any records of the third type with the same temporal position coordinates, a means to determine from those records the record with an optimal quality of view metric to generate a sequence of records of a fourth type with optimal quality views.
According to some embodiments, a means is provided for modifying the order of records in the sequence of records of the fourth type based on the camera ID number and using hysteresis based on one or both of the temporal coordinate or based on the value of the quality metric, to generate a list of a fifth type.
According to some embodiments, a means is provided for interpolating or extrapolating, for at least one or more lists of the fifth type, one or both of; the temporal position coordinates of a point of interest in one or both forwards or backwards directions in recorded time, or the spatial position coordinates of a point of interest, to generate one or more lists of a sixth type comprising a sequence of camera IDs, interpolated or extrapolated temporal position coordinates, or interpolated or extrapolated spatial position coordinates of a point of interest.
According to some embodiments, for at least one or more lists of the sixth type, a means is provided to generate a sequence of views of a point of interest based on the camera IDs, interpolated or extrapolated temporal position coordinates, or interpolated or extrapolated spatial position coordinates of a point of interest.
According to some embodiments, the IDs of the points-of-interest in the sequence of records in the list of the first type are non-contiguous, and the temporal position coordinates are irregularly-sampled in time.
According to some embodiments, the method for extrapolating or interpolating spatial position coordinates of the point of interest is an extrapolation or interpolation algorithm that produces regularly-sampled temporal position coordinates with respect to recorded time.
According to some embodiments, the method for extrapolating or interpolating the temporal position coordinates of the point of interest is based on the expected speed of the object of interest in the camera image. According to some embodiments, the view of a point of interest is generated by selecting a subset of the camera image based on the extrapolated or interpolated spatial position coordinates of the point of interest to generate a camera sub-image. According to some embodiments, the temporal position coordinate with respect to recorded time of a point-of-interest ID in a sequence is computed by determining from the camera image the temporal position coordinate at which a unique characteristic of the object of interest is detected.
According to some embodiments, the temporal position coordinate with respect to recorded time of a point-of-interest ID in a sequence is computed by determining when a stationary proximity sensor is proximate to a moving proximity sensor mounted on the object of interest.
According to some embodiments, the method for entering and then extrapolating or interpolating spatial position coordinates of the point of interest includes a GUI that displays the entered, extrapolated or interpolated spatial position coordinate, and has a means to manually modify the entered, extrapolated or interpolated position coordinate.
According to some embodiments, the method for entering and then extrapolating or interpolating spatial position coordinates of the point of interest includes a GUI that displays the entered, extrapolated or interpolated spatial position coordinate for two or more points of interest on the same camera view, and has a means to manually modify the entered, extrapolated or interpolated position coordinates.
According to some embodiments, the method to manually modify the entered, extrapolated or interpolated position coordinate is to drag the entered, extrapolated or interpolated position coordinates to a different spatial location, and to re-compute and re-display the entered, extrapolated or interpolated position coordinates
According to some embodiments, the method to manually modify the extrapolated or interpolated position coordinate is to delete an entered coordinate and to re-compute the extrapolated or interpolated position coordinates
According to some embodiments, the quality metric for a point of interest in a camera view is determined by the direction of travel of the point of interest.
According to some embodiments, the direction of travel is computed by comparing the actual, interpolated or extrapolated spatial position coordinate at a first temporal coordinate position in recorded time for a point of interest, to a second temporal coordinate position in recorded time for a point of interest.
According to some embodiments, the quality metric for a point of interest in a camera view is determined by the estimated pixel size of the point of interest in the camera view. According to some embodiments, the quality metric for a point of interest in a camera view is determined by the selection of a region in the image in the same or different camera view.
According to some embodiments, the determined quality metric for a point of interest in a camera view is modified by a random component. According to some embodiments, the synthesized video sequence switches between source video clips with a minimum value of time between switches. According to some embodiments, the synthesized video product comprises regions of interest that are spatially fully contained within source video clips while adhering to a model of virtual camera motion.
According to some embodiments, the model of virtual camera motion is that a measure of rapid temporal change in virtual camera motion is below a threshold. According to some embodiments, the measure of rapid temporal change in virtual camera motion is the absolute value of the acceleration of the virtual camera. According to some embodiments, the model of virtual camera motion is that a measure of the magnitude of virtual camera motion is below a threshold.
According to some embodiments, the measure of magnitude of virtual camera motion is the amplitude of the instantaneous velocity of the virtual camera. According to some embodiments, the synthesized video product comprises video clips that are processed using directional blur filters based on the velocity of the virtual camera. According to some embodiments, the velocity of the virtual camera comprises the magnitude and direction of the virtual camera. According to some embodiments, a log records at least the duration of the video used in one or more produced video edits.
In general, when there are multiple cameras acquiring video of multiple participants (or points of interest—POIs), then the different scenarios may include:
Case 1: One or more POIs are visible in a single camera view at the same time
Case 2: One or more POIs are visible in multiple camera views at the same time
Case 3: One or more POIs are visible in multiple camera views at different times
Video of an event may be provided by the public or by an organized production team, and the video acquired may comprise a priori unknown combinations of Case 1, 2 and 3.
In some embodiments, the ID of each POI in each frame of acquired video is determined. As discussed previously, the number of POIs can grow multiplicatively with the number of participants in video as well as with the number of cameras. The present methods can assign the ID of the POIs in each frame using efficient methods that reduce the time to perform the task to manageable levels.
In another example of the automated method in
In some embodiments, the computer then uploads a record to a server dynamically, where the record may comprise at least the detected number of the runner, a unique ID for the camera, and the time at which the video with the detected number was acquired. In some embodiments, the method determines efficiently not only the unique ID of a point of interest in the scene, but also determines attributes of the points of interest. Attributes may include assessments of the speed, 2D position (in image coordinates) or 3D position (in world coordinates) of each point of interest in the scene. The method can determine these attributes efficiently, and may then use them to automatically edit the acquired videos to synthesize produced video.
A first useful attribute may include the 2D and/or 3D position of the POIs in each acquired video scene. An estimate of the 3D position of a point of interest may be particularly useful since it allows assessments of 3D distances and sizes, which may be used by the method for determining a quality metric of the view of a point of interest from a particular camera position. The method may then use this quality metric to determine which camera view to use at a particular time in a produced video edit, as discussed later.
In a second step in the embodiment of the method, a reference 3D surface on which participants would primarily be situated may be identified in the scene. This may be performed by a user selecting points in the scene as in the calibration step, and may use a subset of the same points used in the calibration stage. In some embodiments, a flat 3D plane model is fit to the points. An example of such a 3D plane fitting is R. Kumar, P. Anandan, and K. Hanna, “Direct recovery of shape from multiple views: A parallax based approach,” in Twelfth International Conference on Pattern Recognition (ICPR'94), (Jerusalem, Israel), vol. A, pp. 685-688, IEEE Computer Society Press, October 1994.
The method above showed how in one embodiment the calibration and the ground plane may be used in determining a position attribute for a particular camera view for a POI using a 3D model, for example, of the ground plane. The same method can be repeated for each of a plurality of camera views so that a position attribute for each camera view can be determined for a POI using the same 3D model. In one embodiment, an additional capability of the processing is to compute the position attribute in a second camera view for a POI that has been defined by a user in a first camera view. In the embodiment, the constraint is used that it is the same scene (for example a basketball court) that is being viewed by each camera view except it is being viewed from different spatial locations. By using the 3D model of the scene (for example the floor of the basketball court) then the coordinate transformation that maps the first camera view to the second camera view can be computed using, for example, the same 3D planar recovery model described earlier, for example, R. Kumar, P. Anandan, and K. Hanna, “Direct recovery of shape from multiple views: A parallax based approach,” in Twelfth International Conference on Pattern Recognition (ICPR'94), (Jerusalem, Israel), vol. A, pp. 685-688, IEEE Computer Society Press, October 1994. Once the 3D parameters of this transformation are recovered between all possible combinations of camera views in the calibration step, then if a user clicks on a POI in a first camera view while the system is in operation, then the position attribute in the second, third and any other camera view can be computed automatically from the 3D transformation parameters and the pixel coordinates (or position attributes) of the POI in the first camera view. Using this method the user may then only need to define a POI in a first camera view, and the system can automatically compute corresponding POIs and therefore the corresponding quality metrics in all other camera views. The computed quality metrics from each camera view can then be used to determine which camera view is superior for use in the final broadcast video output at any moment in time, as described above, even though the user only entered in a POI in a first camera view.
In one embodiment, the method interpolates or extrapolates the unknown positions of POIs in frames from measured positions of POIs in other frames. One method for interpolation or extrapolation is to perform a line or curve fit between the 2D coordinates of the clicked point, and to interpolate positions along the recovered line. The same process may be performed using 3D coordinates of the player as computed earlier.
In other embodiments, instead of the operator clicking on the ID marker of the POI, alternate methods of assigning the ID and some positional attributes of POIs may include using the GPS location of devices worn by players, or by having the players wear a Bluetooth or RFID tag, the proximity of which is detected and recorded by a Bluetooth sensor and a computer, several of which are positioned around the event. An embodiment of this is shown in
The position attribute of each POI may be used in a subsequent rendering step of the method to define a region of interest around which a camera view may be synthesized in order to generate a virtual view that highlights the activity of a particular POI, as described in this specification.
In some embodiments, quality metrics are computed and assigned automatically to each POI in each image from each camera view. These metrics may be used during the video production process in order to select automatically which camera view and/or region of interest is preferred at any time instant. One quality metric, pixels-per-meter, of each POI has already been described previously; a large pixels-per-meter metric corresponds to a higher quality metric with respect to the resolution of the POI. In some other embodiments, another quality metric is the speed and/or direction of the POI with respect to each camera view. If the velocity component of the POI in the direction of the camera is towards the camera, then this may have a higher quality metric than if the velocity component of the POI is away from the camera, because a player typically is facing the direction of travel, and the facial view is typically a preferred view in produced video. The velocity component of the POI in the direction of the camera can be computed from the trajectory of the POI computed earlier by taking a difference between points in the trajectory at two adjacent time intervals. For example,
In some other embodiments, the quality metric may be based on the detection of the crowd cheering. In some embodiments this may be detected by measuring the amplitude of the audio signal, and by thresholding it so that if the amplitude is above the threshold then it is determined that the crowd is cheering. This may be used in the editing and rendering process as described herein.
In other embodiments, a quality metric may be the determination that a particular team has scored at a particular moment in time using an annotation entered by an operator. In other embodiments, a quality metric may be the determination that a game or portion of a game has started or ended using an annotation entered by an operator. In other embodiments, a quality metric may be the determination that a player is in possession of the ball using a threshold on the distance from the defined ball position and the defined player position.
In some embodiments, the quality measures may be used to determine whether a video source should be used at all to include a POI in an edited product. For example, a POI in a video may not have enough pixels-per-meter to be acceptable for the purpose of the edit. In some other embodiments, if a POI appears in multiple videos at the same time, then the quality measures may be used to choose which video source should be selected for an edited product at any moment in time.
In some embodiments, one or more video edits are rendered using information that may include the positions of the POIs and their attributes. In cases where the POI is detected only briefly in a video sequence, then in some embodiments a time expansion is applied at or around the recorded time of the detection of the POI to determine the portion of the video to be used in a video edit. For example, in
In some other embodiments, a spatial subset of the source video may be used in a video edit. Even if the video camera used to acquire the source video is fixed, then synthetically selecting and moving the position and size of the subset of the source video may simulate the pan/tilt/zoom of cameras that are traditionally used to follow POIs in edited productions. In some embodiments, the subset of the source video is determined from the position of the POI in the image at each frame as defined by the recovered trajectory (or spatial path). The means of recovering the trajectory of a POI were described earlier. The coordinates of a region at or around the center of the POI may be computed as shown in
The least squares equation for the trajectory in the first and second row of
The fourth row of
In another example,
As discussed previously, one or more quality metrics of each POI computed for each camera view may be used to determine the view used in an edited video at any recorded moment in time. In an example,
In some embodiments, a high quality measure of a particular type measured from a first camera view or sensor can trigger an edited view from a second camera view. For example if an audio sensor detects the audience cheering as described earlier, then the edited view may switch to a region of interest in a second camera view that has been pre-defined by an operator to include the audience.
In some other embodiments, the system uses the determination that a game or portion of game has started or ended to control the edit by performing a virtual pan/tilt/zoom of a camera when the game is not in progress to introduce synthetic camera motion and to retain the attention of the viewer until the game begins again.
In some other embodiments, if a player is designated as just having received a ball, then the edit may switch to display the player at a larger pixels-per-meter rate from the same camera view, or display the player from a second camera view for a pre-determined period of time.
In some other embodiments, hysteresis is introduced into the synthetic camera pan/tilt/zoom position such that the synthetic camera position does not move unless the player or ball or other region of interest moves by more than a predefined percentage of a dimension of the camera field of view. This prevents small-amplitude movements in the camera that are distracting while still maintaining relevant action in the field of view of the virtual camera.
In some other embodiments, if it is determined that a particular player has possession of the ball, then the synthetic view is chosen to be spatially biased to view more of the game area in which is predicted the player will move. This is performed by determining from the player ID which target goal in which the team is aiming to score. The positions of the goals in a camera field of view are pre-defined by an operator. A synthetic view is then chosen to be centered at or near a point between the position of the player and the position of the target goal. This bias in chosen viewpoint increases video coverage of defensive action in the game in response to offensive player movements.
In another embodiment, a random element is introduced into the view synthesis rule structure such that a random view synthesis is chosen out of a selected set of acceptable preferred views. This adds some variety to the edited video and avoids repetitive scene transitions.
In another embodiment, a random component is added to the position of the synthesized camera motion. This adds some variability into the position of the camera to simulate the camera motion that would occur if the viewing position of the camera was controlled by a human.
In another embodiment, a motion blur filter is performed on the synthesized view in the direction of the velocity of the synthesized camera view. This is to simulate motion blur that would occur in a real camera introduced by image integration over several camera pixels in the direction of camera motion. The rendering process can be performed using quality metrics computed for any number of POIs from any number of source videos. Therefore different, unique edited videos may be produced for each POI. In addition, as different rules are applied to the quality metrics, then different produced videos may be generated for a single POI, each produced video focusing automatically on different aspects of the POI, for example focusing on shots taken or on shots defended.
In another embodiment, a log is generated that stores the identity of the source of a video clip used in an edited result, along with at least the duration of the video clip used in the edited result. This can be used for accreditation of a video provider for the video clip used in the produced video.
In one embodiment, a video processor (e.g., of a video production system) includes a video input module and a video output module, and is connected to a user interface module such as a mouse or joystick and a display module such as a computer screen. The video output module is capable of producing images successively at a periodic interval. The user interface module may be a computer mouse, joystick or other input device, and the user may click aperiodically on the input video frames that are presented to the user by means of the display module. As views of different scenes from the input video are presented to the user, the user may click aperiodically on a particular location, or a point of interest (POI). For example, a POI may be the location of a ball in a sports event. The user may be unskilled in the art of broadcasting, and this means that while the user may provide general input on where the activity is, the user may be unable to adhere to standards or achieve quality metrics that in some embodiments define acceptable video for broadcasting purposes. In addition, since the output module produces images successively at a periodic interval at a rapid rate, typically at 25 Hz or 30 Hz (frames per second), the user is physically incapable of providing input of any type for each frame at that rate. The user therefore can only provide input on only a subset of the image frames presented to the user. The POI identified by the user input can be used to define a region of interest (ROI) for inclusion in the output images. The specific ROI is the result of processing as described herein, but in an example output of the processing, the ROI may be an area surrounding the POI, with the POI being close to the center of the ROI.
Different users may identify different POIs even if the input imagery is the same. For example, a first user may click aperiodically on a first player as a POI, while a second user may click aperiodically on a second player as a POI. Alternatively, if the input video is from a recorded video stream, then the same first user may click on a first player as a POI in one pass of the input video, and then may rewind the input video and then may click on the second player as a POI in a second pass of the input video for instance.
In some embodiments the user or video production system may pre-define a bounding scene of interest (BSI) representing a predetermined extent of a field of view of a corresponding camera, and such that the area outside the BSI is undesirable for image frame acquisition. For example, in the case of a fixed or static high resolution 4K pixel camera, the BSI may be the full extent of the acquired image. In other embodiments, it may be a rectangular region of interest that does not include the sky and only includes the sports arena. The BSI provides information to the processing, described later, that will be used to constrain the scene regions from where the regions of interest (ROI) for the produced video images is selected, in order to satisfy one aspect of producing high quality video. For example, in the case again of a fixed high resolution 4K pixel camera, in one embodiment one aspect of producing high quality video is that the region of interest is fully contained within the 4K pixel camera view, and does not include areas that lie outside this area, since those areas have no pixel values and therefore may be output as black, or some other synthetic set of pixel values that do not correspond to the real scene, and that are therefore poor quality and undesirable in terms of the production of broadcast video.
In another embodiment and for the case of a pan/tilt/zoom (or real) camera, the physical camera is typically capable of being pointed at a very wide area of the scene. The desired BSI in this case may be the region of the pitch (e.g., playing field) of a sports event, which is only a subset of the region where the pan/tilt/zoom camera can be physically pointed.
The BSI may be defined, in the case of a fixed camera, by the user defining by means of a mouse, a rectangular box within the field of view of the fixed camera. In some embodiments the rectangular box may be the same as the field of view of the camera. In the case of a pan/tilt/zoom camera that supports spatial pan, spatial tilt and/or optical zoom functions, the BSI may be defined by the user pointing the camera at each of: the top left, top right, bottom left, bottom right of the scene that is of interest, and the pan/tilt angular coordinates of the camera at each of the 4 points are read and stored in a configuration file to define the BSI. During subsequent processing, the pan/tilt angular coordinates can be read and the position of the camera with respect to the boundaries of the BSI can be computed by taking the difference between the current angular coordinates and the stored angular coordinates.
In some embodiments, the BSI may comprise two BSI's cascaded together. For example, a high resolution 4K camera may be mounted on a pan/tilt/zoom mount. A first BSI may be defined by the 4K camera view. A second BSI may be defined by the view provided by changing the pan/tilt/zoom camera mount. This cascading of BSIs to effect a single BSI may be useful in some embodiments since in the first BSI (from the 4K camera view), all pixels in the BSI are captured such that any output ROI at any time instant, either forwards or backwards, can be selected as a result of the processing. In the second BSI (due to the pan/tilt/zoom mount) only some pixels in the BSI are captured, so that only some ROIs at a particular time instant can be selected. The second BSI is however potentially much larger than the first BSI due to the pan/tilt/mount. In some embodiments, by cascading both BSIs into a single BSI, in some embodiments compared to a single BSI there is the advantage of a larger combined BSI together with a larger ability to select ROIs from more time instants, both backwards and forwards.
The processing dynamically adjusts the field of view of the camera for image frame acquisition, to steer subsequently acquired image frames and corresponding scenes for the video to be contained within the BSI, and such that the scenes are arranged successively at a periodic interval, even if the user input is aperiodic as described earlier. In some embodiments, the camera view within the BSI can be defined as a virtual camera that uses digital pan, tilt and/or zoom functions to identify portions of high definition source images to be extracted as the image frames, and the BSI corresponds to image boundaries of the high definition source images. In some embodiments, the dynamic adjustment performed by the processor dynamically adjusts the field of view of the camera view to provide a smooth spatial transition of corresponding elements across the scene of the video. For example, even if the user clicks the mouse at the top of the BSI, then the bottom of the BSI and then the top of the BSI again, the processing would smooth the spatial transition of the output regions of interest so that the motion trajectory of the output video appears smooth even if the motion trajectory from the user input is not smooth. In some embodiments, high quality broadcast video should appear smooth. The particular methods for smoothing the camera trajectory while at the same time identifying ROIs of other image frames for inclusion as scenes in the video are described in more detail herein. However the methods may include interpolating and/or extrapolation methods, whereby the sparse and aperiodic mouse click positions inputted by the user are in some embodiments processed to achieve one or more of three objectives simultaneously: a) identify an ROI that would comprise an output image frame at a periodic rate, b) ensure that each ROI is within the BSI, and c) ensure that the spatial trajectory formed by the ROI over multiple output images is smooth. This ensures that the quality of the output video is suitable for broadcasting, at least with respect to the aforementioned factors.
In some other embodiments, additional quality metrics are also computed in order to optimize the quality of the output video with respect to other factors. In one embodiment, a quality metric for each of the image frames comprises a pixel resolution of a reference POI in each of the corresponding image frames. As described later, the reference POI may be computed by modeling the scene, such that, for example, if a POI selected by the user is at a far end of a playing field with respect to the camera position, then the pixel resolution can be computed to be lower compared to the pixel resolution computed if the user had selected a position at the near end of the playing field. This process can be repeated using multiple cameras that may be positioned at different locations around a playing field. A user may click on a POI in one camera, and using the 3D model, a resolution quality metric can be computed. Using the 3D model, the same POI from the perspective of the second camera and having the same temporal position coordinate is automatically computed. A second resolution quality metric is then computed using that resolution quality metric. In some embodiments, the processing then selects as an output image the image from the first camera if the quality metric of the first image frame is better than that of the second image frame from the second camera. In a specific illustrative example of an embodiment, a first camera may be at one end of a baseball court, and a second camera may be at the other end of the court. The user may click only on images from the first camera. As activity moves further from the first camera, the user may click on regions that are also further away from the first camera such that the computed quality metric from the first camera lowers while the computed quality metric for the second camera increases. As the POI moves to approximately half way across the court, the quality metric for the second camera may be computed to be greater than the quality metric for the first camera. In some embodiments the output video is then controlled to switch from images from the first camera to images from the second camera so that objects that are closer and therefore are at a higher resolution are shown.
In some embodiments, a quality metric may be one of a speed or direction of a reference POI. For example, the direction of a POI may be the direction that a player or subject in the image is looking. In some embodiments, the detection of a face in a first camera view may determine that the player or subject is looking towards the camera and a quality metric may be defined to be high, whereas the inability to detect a face may determine that the player or subject is looking away from the camera and a quality metric may be defined to be low. As described previously, this quality metric can be computed on one or more camera views and in some embodiments the output imagery is selected from the camera views with the highest quality. In an illustrative example, if a player runs up the court facing a camera, then the output imagery would show the face of the player from a first camera view. If the player then runs in the opposite direction then the output imagery would be selected to also show the face of the player but this time from the second camera view. In this illustrative example, it is preferred in high quality broadcast video to show faces of players, as opposed to the backs of their heads.
In a related embodiment, the one or more quality metrics computed as described above may be subjected to hysteresis-based selection of a first image over a second image by adjusting a threshold or trigger for selecting the first image over the second image. To illustrate the purpose of the hysteresis-based selection in one embodiment, consider a player on the court that the user defines as an ROI. If the player is moving back and forth in the vicinity of the half-court position with a camera on either end of the court. The quality metric (computed by detecting the pixel resolution as described previously) would be very similar for each camera view such that the highest quality metric would switch rapidly from one camera view to the next, and if the raw quality metric is used to control the camera view, then the output imagery would also rapidly switch from one camera view to the next. In high quality video however, rapid switching between camera views is undesirable. In the embodiment, the problem is alleviated by use of hysteresis-based selection. In this method, the difference in quality metric has to exceed a threshold or trigger value before the current camera output is allowed to switch to a different camera output. In this way, rapid switching between camera views is eliminated.
In some embodiments, the user may designate an incorrect POI by mistake, such that the generated spatial path of the ROI is also incorrect. In some embodiments, the user interface may have a correction button that allows the user to specify a correction by modifying or deleting a POI, after which the generated spatial path of the ROI is updated using the modified set of current and previously-entered POIs.
Referring to
Referring to (1201), and in some embodiments, image frames for use in producing a video is presented to a user on a display of a video production device. The video being produced is to have scenes arranged successively at a periodic interval, each of the presented image frames corresponding to a separate scene. The image frames may be presented in temporal sequence or in any sequence, e.g., as determined by the user. In some embodiments, the image frames are acquired via two or more cameras and/or two or more viewpoints. Some of the image frames may correspond to a same temporal position coordinate (e.g., acquired at the same instant in time), and may offer alternative viewpoints of a POI for instance, for selection to include in the video being produced.
In some embodiments, the images frames may be presented to the user as a live feed or in real time, or near real time. In some embodiments, the images frames are pre-recorded images (e.g., retrieved from storage) and are played back or otherwise presented as an input video to the user. Multiple ones of the image frames (or scenes) may be presented to the user at the same time (e.g., on the same display screen or multiple display screens) or sequentially. The user may have control over the speed at which the image frames are presented to the user, and may apply video playback or trick mode control (e.g., pause, reverse, fast forward, slow advance) over the presentation of the image frames.
Referring to (1203), and in some embodiments, a video processor may receive, via a user interface of the video production device, inputs from the user for only a subset of the image frames. Each of the inputs may indicate a point of interest (POI) in a corresponding image frame. For instance, as views of different scenes from the input video are presented to the user, the user may click aperiodically on a particular location, or a POI (e.g., a player or a ball). The user may select one or more POIs within certain image frames. For example, the user may sparsely, sporadically, aperiodically, asynchronously and/or randomly select one or more POIs on only a subset of the image frames, because the associated frame rate may be faster than the user's selection speed/rate. In some embodiments, the user inputs/selections/clicks are meant to guide scene selection for video production, to be extrapolated and/or interpolated to other image frames not addressed by the user. In some embodiments, the user interface may incorporate mouse, joystick, touch pad, touch screen or other selection/click functions.
The POI selected or indicated by the user input may be indicative of a region of interest (ROI) for inclusion as a scene in the video. In some embodiments, the selected POI defines a region or portion of a corresponding image frame, to be included as a scene in the produced video. For example, the video production system may define an image area around and/or including the selected POI, as a scene to be included in the video to be produced. Different users may click on different POIs and/or different subsets of the image frames, and result in different produced videos.
Referring to (1205), and in some embodiments, the video processor may evaluate a spatial path of the indicated POIs relative to a bounding scene of interest (BSI). The video processor may connect the POIs across various image frames, or determine a curve/path of best fit, to generate the spatial path. The video processor may generate the spatial path by at least one of interpolating or extrapolating from the indicated POIs. The video processor may dynamically generate a new spatial path or update an existing path as new user input(s) are received.
The BSI may represent a predetermined extent of a field of view of a corresponding camera for image frame acquisition. In some embodiments, the BSI is determined based on the context of the camera. In some embodiments, the camera corresponds to a real camera, e.g., that supports spatial pan, spatial tilt and/or optical zoom functions. Such a camera may be referred to as a pan/tilt/zoom camera, and may comprise any mounted or handheld camera. For instance, the camera may be mounted to a pole, wall or other structure, and can be adjusted to perform spatial pan, spatial tilt and/or optical zoom functions. Here, the BSI is at least in part defined or limited by capabilities of the spatial pan, spatial tilt and/or optical zoom functions. For example, the extent of spatial pan, spatial tilt and/or optical zoom by the camera may limit the extent of the camera's field of view for image frame acquisition. In some embodiments, the BSI is at least in part defined by a portion of a scene determined to be undesirable for image frame acquisition. For example, the portion of the scene may include a visual obstacle, blockage or barrier such as a light pole or structural column. In some cases, the portion of the scene may be determined to be undesirable because the portion includes a visual blight such as a trash can, a construction site, or a damaged or vandalized structure.
In some embodiments, the camera corresponds to a virtual camera that uses digital pan, tilt and/or zoom functions to identify portions of high definition source images to be extracted as the image frames. The temporal positional coordinate of such an extracted image frame may correspond to that of the underlying high definition source image. The BSI may correspond to image boundaries of the high definition source images. The high definition source images may be acquired by a real camera, e.g., a static camera or a pan/tilt/zoom camera. In certain embodiments, the camera comprises a hybrid camera that supports spatial pan, spatial tilt, optical zoom, digital pan, digital tilt and/or digital zoom functions, and the BSI is at least in part defined by capabilities of the spatial pan, spatial tilt and/or optical zoom functions. For instance, the hybrid camera may incorporate a virtual camera with further access to spatial pan, spatial tilt and/or optical zoom functions of the associated real camera.
Referring to (1207), and in some embodiments, the video processor may dynamically adjust, in response to the evaluation, the field of view of the camera for image frame acquisition, to steer subsequently acquired image frames and corresponding scenes for the video to be contained within the BSI. Since it may not be possible or desirable to acquire imagery beyond the BSI, a given spatial path or trajectory of a POI can be used to predict if the corresponding scenes are expected to extend beyond the BSI, and to trigger adjustments to the video being produced. The video processor may generate the spatial path and evaluate the spatial path with respect to the BSI. The video processor may determine the proximity/distance and/or speed of approach of the spatial path relative to the BSI. The video processor may dynamically adjust, in response to the determination or evaluation, the field of view of the camera for image frame acquisition, to steer subsequently acquired image frames and corresponding scenes for the video to be contained within the BSI. For example, the video processor may adjust or shift a ROI relative to a POI, to contain the ROI within the BSI.
In some embodiments, the video processor adjusts according to the spatial trajectory, one or more of the ROIs of the subset of image frames, for inclusion as one or more scenes in the video. The video processor may dynamically adjust the field of view of the camera for image frame acquisition to provide smooth spatial transition of corresponding elements across the scenes of the video. For instance, the video processor may gradually adjust or shift ROIs relative to POIs, to contain the ROIs within the BSI, and to ensure a smooth transition between the ROIs or scenes in the produced video.
In certain embodiments, the video processor receives, via the user interface, an input from the user specifying a correction to a position of a first POI in the generated spatial path. For instance, the user may click on a different POI or location of an image frame, from one identified earlier, as a corrective action. The video processor may update, responsive to the correction (or corrective action), one or more ROIs for inclusion as scenes in the video. For example, the video processor may update the spatial path based on the correction, and may update or replace one or more ROIs for inclusion as scenes in the video.
In some embodiments, the video processor determines a quality metric for each of the image frames. In some embodiments, the video processor selects a first image frame acquired using the first video camera over a second image frame acquired using the second video camera and having a same temporal position coordinate as the first image frame, to use in the video, responsive to determining that the quality metric of the first image frame is better than that of the second image frame. The quality metric may comprise a pixel resolution of a reference POI in each of the corresponding image frames. A first number of the image frames may be acquired using a first video camera and a second number of the image frames may be acquired using a second video camera. The video processor may determine that the quality metric of a first image frame is better than that of a second image frame. The video processor may select the first image frame acquired using the first video camera over the second image frame acquired using the second video camera and having a same temporal position coordinate as the first image frame, to use in the video, responsive to determining that the quality metric of the first image frame is better than that of the second image frame.
In some embodiments, the video processor determines a quality metric for each of the image frames according to at least one of a speed or direction of a reference POI with respect to a corresponding camera viewpoint. A first number of the image frames may be acquired using a first video camera and a second number of the image frames may be acquired using a second video camera. The video processor may determine that the quality metric of a first image frame is better than that of a second image frame. For instance, the quality metric of a first image frame may be better because the POI in the first image frame has been identified as a key element/character of the video being produced, because the POI is facing, approaching, and/or accelerating towards the camera.
The video processor may perform hysteresis-based selection of a first image frame over a second image frame having a same temporal position coordinate as the first image frame, to use in the video, by adjusting a threshold or trigger for selecting the first image frame over the second image frame. The video processor may select a first image frame over a second image frame according to a temporal or other filter. The video processor may select a first image frame over a second image frame according to a threshold or trigger set by the user for instance.
In some embodiments, the video processor determines at least a first quality metric for a first POI or a second quality metric for a second POI, for each of the image frames. The video processor may select a first image frame over a second image frame having a same temporal position coordinate as the first image frame, to use in the video, responsive to determining that the at least a first quality metric for a first POI and a second quality metric for a second POI of the first image frame, is better than that of the second image frame.
Referring to (1209), and in some embodiments, the video processor may produce, in accordance with the dynamic adjustment, the video with all scenes arranged successively at the periodic interval. The video processor may perform at least one of interpolating or extrapolating, using the POIs of the subset of image frames, to identify ROIs of other image frames for inclusion as scenes in the video.
Each of the elements, modules, submodules or entities, referenced herein in connection with any embodiment of the present systems or devices, is implemented in hardware, or a combination of hardware and software. For instance, each of these elements, modules, submodules or entities can include any application, program, library, script, task, service, process or any type and form of executable instructions executing on hardware of the respective system. The hardware includes circuitry such as one or more processors, for example.
It should be understood that the systems described above may provide multiple ones of any or each of those components and these components may be provided on either a standalone machine or, in some embodiments, on multiple machines in a distributed system. The systems and methods described above may be implemented as a method, apparatus or article of manufacture using programming and/or engineering techniques to produce software, firmware, hardware, or any combination thereof. In addition, the systems and methods described above may be provided as one or more computer-readable programs embodied on or in one or more articles of manufacture. The term “article of manufacture” as used herein is intended to encompass code or logic accessible from and embedded in one or more computer-readable devices, firmware, programmable logic, memory devices (e.g., EEPROMs, ROMs, PROMs, RAMs, SRAMs, etc.), hardware (e.g., integrated circuit chip, Field Programmable Gate Array (FPGA), Application Specific Integrated Circuit (ASIC), etc.), electronic devices, a computer readable non-volatile storage unit (e.g., CD-ROM, floppy disk, hard disk drive, etc.). The article of manufacture may be accessible from a file server providing access to the computer-readable programs via a network transmission line, wireless transmission media, signals propagating through space, radio waves, infrared signals, etc. The article of manufacture may be a flash memory card or a magnetic tape. The article of manufacture includes hardware logic as well as software or programmable code embedded in a computer readable medium that is executed by a processor. In general, the computer-readable programs may be implemented in any programming language, such as LISP, PERL, C, C++, C#, PROLOG, or in any byte code language such as JAVA. The software programs may be stored on or in one or more articles of manufacture as object code.
While various embodiments of the methods and systems have been described, these embodiments are exemplary and in no way limit the scope of the described methods or systems. Those having skill in the relevant art can effect changes to form and details of the described methods and systems without departing from the broadest scope of the described methods and systems. Thus, the scope of the methods and systems described herein should not be limited by any of the exemplary embodiments and should be defined in accordance with the accompanying claims and their equivalents.
This application claims priority to and the benefit of U.S. Provisional Patent Application No. 62/297,977, filed Feb. 22, 2016, U.S. Provisional Patent Application No. 62/303,944, filed Mar. 4, 2016, and U.S. Provisional Patent Application No. 62/319,371, filed Apr. 7, 2016, the entire content of each of which is incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
62297977 | Feb 2016 | US | |
62303944 | Mar 2016 | US | |
62319371 | Apr 2016 | US |