US8175379B2 - Automatic video image segmentation - Google Patents

Automatic video image segmentation Download PDF

Info

Publication number
US8175379B2
US8175379B2 US12/275,096 US27509608A US8175379B2 US 8175379 B2 US8175379 B2 US 8175379B2 US 27509608 A US27509608 A US 27509608A US 8175379 B2 US8175379 B2 US 8175379B2
Authority
US
United States
Prior art keywords
segmentation
local
color model
current image
shape
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active, expires
Application number
US12/275,096
Other versions
US20100046830A1 (en
Inventor
Jue Wang
Xue Bai
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Adobe Inc
Original Assignee
Adobe Systems Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Adobe Systems Inc filed Critical Adobe Systems Inc
Priority to US12/275,096 priority Critical patent/US8175379B2/en
Assigned to ADOBE SYSTEMS INCORPORATED reassignment ADOBE SYSTEMS INCORPORATED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BAI, XUE, WANG, JUE
Assigned to ADOBE SYSTEMS INCORPORATED reassignment ADOBE SYSTEMS INCORPORATED ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: BAI, XUE, WANG, JUE
Priority to CN2009102057713A priority patent/CN101676953B/en
Publication of US20100046830A1 publication Critical patent/US20100046830A1/en
Priority to US13/448,162 priority patent/US8422775B2/en
Application granted granted Critical
Publication of US8175379B2 publication Critical patent/US8175379B2/en
Assigned to ADOBE INC. reassignment ADOBE INC. CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: ADOBE SYSTEMS INCORPORATED
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/10Segmentation; Edge detection
    • G06T7/12Edge-based segmentation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/10Image acquisition modality
    • G06T2207/10016Video; Image sequence
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/30Subject of image; Context of image processing
    • G06T2207/30196Human being; Person

Definitions

  • the present invention is directed generally to digital image processing, and more particularly to automatic segmentation of images in a video sequence.
  • Digital images may include raster graphics, vector graphics, or a combination thereof.
  • Raster graphics data (also referred to herein as bitmaps) may be stored and manipulated as a grid of individual picture elements called pixels.
  • a bitmap may be characterized by its width and height in pixels and also by the number of bits per pixel.
  • a color bitmap defined in the RGB (red, green blue) color space may comprise between one and eight bits per pixel for each of the red, green, and blue channels.
  • An alpha channel may be used to store additional data such as per-pixel transparency values.
  • Vector graphics data may be stored and manipulated as one or more geometric objects built with geometric primitives.
  • the geometric primitives e.g., points, lines, polygons, Bézier curves, and text characters
  • Digital image processing is the process of analyzing and/or modifying digital images using a computing device, e.g., a computer system. Using specialized software programs, digital images may be manipulated and transformed in a variety of ways.
  • a segmentation shape prediction and a segmentation color model for a current image (e.g., a first image) of a video sequence may be determined based on existing segmentation information for at least one previous image of the video sequence. For example, in one embodiment, a user may manually segment the current image into a foreground and a background, storing the segmentation information for this current image, including a segmentation contour that divides the background from foreground, e.g., a foreground object, in the image.
  • the determination of the shaped prediction and color model may be performed via any of a variety of techniques, as desired.
  • scale invariant feature transform (SIFT) techniques may be employed to generate an estimate or rough version of the segmentation contour for the current image based on the at least one previous image of the sequence, i.e., based on the pre-existing segmentation contour.
  • SIFT key points are reliable features for consecutive frames in videos. By matching the SIFT key points of the previous image/frame with corresponding key points in the current image/frame, one can determine a good initial guess of the contour in the current (or new) frame.
  • the initial contour may be transformed to generate a rough estimate or predicted shape of the contour for the subsequent frame.
  • a plurality of local classifiers may be constructed along the contour and used to perform operations with respect to the contour.
  • a sliding window approach may be employed, where each classifier, whose center point lies on the contour, defines and operates on a local region around a respective contour point (the classifier's center), integrating color and shape information from the previous frame, e.g., a color model and a shape prediction, and determining the predicted contour accordingly.
  • the shape alignment process may operate to roughly align the classifier windows with the foreground object in frame i+1.
  • generating a local segmentation shape prediction based on the respective portion of the shape contour may include generating an initial local segmentation shape prediction via scale invariant feature transform (SIFT) applied to a plurality of key points in the respective region, and generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour.
  • SIFT scale invariant feature transform
  • generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour may include determining a local average flow vector based on optical flow of foreground pixels in the respective region, and applying the local average flow vector to the points along the respective portion of the shape contour to generate the local segmentation shape prediction.
  • a local segmentation color model may be generated based at least on color information for the respective region of the at least one previous image included in the local classifier.
  • a local average flow inside the contour may be used.
  • a more accurate and robust estimated contour may be generated.
  • This predicted or estimated contour may then be used as a shape prior (shape prediction) and may specify positions of the local classifiers.
  • GMM Gaussian Mixture Model
  • generating a local segmentation color model may include generating a local segmentation simple color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image, and generating a local segmentation mixed color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image and color information for the respective region of the current image included in the local classifier for the current image. Discriminability of the local segmentation mixed color model and the local segmentation simple color model may be determined.
  • Generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier may then include selecting the local segmentation simple color model as the local segmentation color model if the local segmentation simple color model has greater discriminability than the local segmentation mixed color model, and selecting the local segmentation mixed color model as the local segmentation color model if the local segmentation mixed color model has greater discriminability than the local segmentation simple color model.
  • a shape prior i.e., a predicted shape
  • the contribution from the predicted shape may be based on the discriminability of the color model, where if the color model makes a clear distinction between foreground colors and background colors, the color model is relied on to classify the pixels of the region, and if the color model does not make a clear distinction, the shape prior is relied on to classify the pixels, with intermediate situations addressed by weights applied to each, e.g., where the weights sum to some normalized value, e.g., 1.
  • the weights are coefficients in a linear sum of the color and shape contributions. Note, however, that in other embodiments, the shape and color contributions may be determined by a non-linear combination.
  • each classifier may determine a probability or feature map for a respective portion of the image proximate to the estimated contour.
  • the probabilities (i.e., probability or feature maps) in all local windows, i.e., from all local classifiers may be combined to form a combined feature map.
  • a local feature map estimation may be generated based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, where the local feature map estimation classifies pixels in the respective region as background or foreground pixels.
  • a feature map estimation for the current image may be generated by combining the local feature map estimations.
  • a combined probability or feature map for the image (e.g., of frame i+1) may be determined using both color models and shape predictions for each of a plurality of local classifiers.
  • a plurality of local feature maps, e.g., foreground masks may be stitched together to form a global or combined feature map or mask.
  • a segmentation of the current image may be automatically generated based on a weighted combination of the segmentation shape prediction and the segmentation color model.
  • the combined feature (probability) map may be used to segment the image (into foreground and background portions).
  • the combined feature map i.e., the generated feature map estimation for the current image
  • the probability values may be set as data cost, after which a GAC (Geodesic Active Contour) algorithm may be performed to further regularize the boundary, e.g., implemented by level sets.
  • GAC Gateodesic Active Contour
  • the local feature maps may each be used to perform a local segmentation for each classifier window, after which these local segmentations (segmented image portions) may be stitched together to form the segmented image.
  • the segmentation of the current image may be stored, e.g., in a memory medium of the computer system, and/or a memory medium coupled to the computer system, e.g., over a network, e.g., a SAN.
  • the method may then repeat the above-described method elements for subsequent images or frames of the video sequence, as described below in more detail.
  • the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, the automatically generating a segmentation of the current image, and the storing of the segmentation of the current image may be repeated for one or more contiguous images in the video sequence.
  • various embodiments of the systems and methods disclosed herein may be used to automatically perform image segmentation in a digital video image sequence.
  • FIG. 1 is a block diagram of an exemplary system configured to implement embodiments of the present invention
  • FIG. 2 illustrates an exemplary video image processing module, according to one embodiment
  • FIG. 3 illustrates an exemplary video sequence with segmentation/masking, according to one embodiment
  • FIG. 4 is a high level diagram of an exemplary single frame propagation approach to automatic image segmentation, according to one embodiment
  • FIG. 5 illustrates an iterative aspect of the single frame propagation approach of FIG. 4 , according to one embodiment
  • FIG. 6 is a high level diagram of an exemplary multi-frame propagation approach to automatic image segmentation, according to one embodiment
  • FIG. 7 is a flowchart illustrating a method for performing automatic segmentation of images in a video sequence, according to one embodiment
  • FIGS. 8 and 9 illustrate scale invariant feature transform (SIFT) of key points in consecutive video frames, according to one embodiment
  • FIG. 10 illustrates optical flow of a contour point in a video frame, according to one embodiment
  • FIG. 11 illustrates prediction of a segmentation contour in successive video frames, according to one embodiment
  • FIG. 12 illustrates local classifiers in successive video frames, according to one embodiment
  • FIG. 13 illustrates local color and shape integration with adaptive weights, according to one embodiment
  • FIG. 14 illustrates candidate local color models, according to one embodiment
  • FIG. 15 illustrates use and results of the two candidate color models of FIG. 14 , according to one embodiment
  • FIG. 16 illustrates shape prediction confidence, according to one embodiment
  • FIG. 17 illustrates shape prediction constraints based on discriminativity of the color model, according to one embodiment
  • FIG. 18 illustrates color and shape integration, according to one embodiment
  • FIG. 19 illustrates contour iteration with respect to feature map estimation and segmentation, according to one embodiment
  • FIG. 20 illustrates multi-frame propagation of segmentation using a color model of an initial frame, according to one embodiment
  • FIG. 21 illustrates multi-frame propagation of segmentation using a feedback correction approach with respect to window/classifier positions, according to one embodiment
  • FIG. 22 illustrates user interaction to correct or reset multi-frame propagation of segmentation in a video sequence, according to one embodiment
  • FIGS. 23 and 24 illustrate exemplary video sequences resulting from application of embodiments of the method of FIG. 7 .
  • Embodiments of the systems and methods described herein may be used to automatically perform video image segmentation, e.g., of a region or object of interest, e.g., a foreground object, in a digital video sequence. More specifically, embodiments of the systems and methods disclosed herein may be used to analyze sequential digital video images or frames, and to propagate an initial image segmentation of a frame to one or more subsequent frames, e.g., to automatically generate a sequence of foreground masks for corresponding video frames in a video sequence, based on an initial pre-existing segmentation or mask for an initial or key frame in the sequence.
  • Examples of applications for such masks include, but are not limited to, special effects in digital films, e.g., removing or replacing backgrounds, applying effects to different image layers, and so forth, as well as image decomposition and analysis, e.g., for scientific or security applications, e.g., monitoring, surveillance, face recognition, etc.
  • operations or processing involve physical manipulation of physical quantities.
  • quantities may take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared or otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to such signals as bits, data, values, elements, symbols, characters, terms, numbers, numerals or the like. It should be understood, however, that all of these and similar terms are to be associated with appropriate physical quantities and are merely convenient labels.
  • FIG. 1 is a block diagram illustrating constituent elements of a computer system 100 that is configured to implement embodiments of the systems and methods described herein.
  • the computer system 100 may include one or more processors 110 implemented using any desired architecture or chip set, such as the SPARCTM architecture, an x86-compatible architecture from Intel Corporation or Advanced Micro Devices, or an other architecture or chipset capable of processing data. Any desired operating system(s) may be run on the computer system 100 , such as various versions of Unix, Linux, Windows® from Microsoft Corporation, MacOS® from Apple Inc., or any other operating system that enables the operation of software on a hardware platform.
  • the processor(s) 110 may be coupled to one or more of the other illustrated components, such as a memory 120 , by at least one communications bus.
  • a specialized graphics card or other graphics component 156 may be coupled to the processor(s) 110 .
  • the graphics component 156 may include a graphics processing unit (GPU) 170 , which in some embodiments may be used to perform at least a portion of the techniques described below.
  • the computer system 100 may include one or more imaging devices 152 .
  • the one or more imaging devices 152 may include various types of raster-based imaging devices such as monitors and printers.
  • one or more display devices 152 may be coupled to the graphics component 156 for display of data provided by the graphics component 156 .
  • program instructions 140 that may be executable by the processor(s) 110 to implement aspects of the techniques described herein may be partly or fully resident within the memory 120 at the computer system 100 at any point in time.
  • the memory 120 may be implemented using any appropriate medium such as any of various types of ROM or RAM (e.g., DRAM, SDRAM, RDRAM, SRAM, etc.), or combinations thereof.
  • the program instructions may also be stored on a storage device 160 accessible from the processor(s) 110 .
  • any of a variety of storage devices 160 may be used to store the program instructions 140 in different embodiments, including any desired type of persistent and/or volatile storage devices, such as individual disks, disk arrays, optical devices (e.g., CD-ROMs, CD-RW drives, DVD-ROMs, DVD-RW drives), flash memory devices, various types of RAM, holographic storage, etc.
  • the storage 160 may be coupled to the processor(s) 110 through one or more storage or I/O interfaces.
  • the program instructions 140 may be provided to the computer system 100 via any suitable computer-readable storage medium including the memory 120 and storage devices 160 described above.
  • the computer system 100 may also include one or more additional I/O interfaces, such as interfaces for one or more user input devices 150 .
  • the computer system 100 may include one or more network interfaces 154 providing access to a network. It should be noted that one or more components of the computer system 100 may be located remotely and accessed via the network.
  • the program instructions may be implemented in various embodiments using any desired programming language, scripting language, or combination of programming languages and/or scripting languages, e.g., C, C++, C#, JavaTM, Perl, etc.
  • the computer system 100 may also include numerous elements not shown in FIG. 1 , as illustrated by the ellipsis.
  • FIG. 2 illustrates an exemplary image analysis module that may implement embodiments of a method for automatically propagating video image segmentation, as described below with reference to FIG. 6 .
  • module 200 may provide a user interface 202 that includes one or more user interface elements via which a user may initiate, interact with, direct, and/or control the method performed by module 200 .
  • Module 200 may obtain a set of digital video images 210 and, optionally, user input 212 , analyze an initially segmented image or frame and one or more subsequent frames, and propagate the initial image segmentation to the subsequent one or more frames.
  • Segmentation information 204 e.g., information specifying or facilitating segmentation, and may be used to perform the image analysis or processing.
  • Image analysis module 200 may be implemented as or in a stand-alone application or as a module of or plug-in for a video processing and/or presentation application.
  • Examples of types of applications in which embodiments of module 200 may be implemented may include, but are not limited to, video editing, processing, and/or presentation applications, as well as applications in security or defense, educational, scientific, medical, publishing, digital photography, digital films, games, animation, marketing, and/or other applications in which digital video image editing or presentation may be performed, e.g., where operations are to be directed to different layers of images.
  • Specific examples of applications in which embodiments may be implemented include, but are not limited to, Adobe® Photoshop® and Adobe® Illustrator®.
  • module 200 may be used to display, manipulate, modify, and/or store the output images, for example to a memory medium such as a storage device or storage medium.
  • One embodiment disclosed herein provides a robust interactive system and method for video object segmentation. Based on pre-existing segmentation information for a previous (or any other) frame in a video sequence, e.g., provided by a user, e.g., via manual segmentation of the previous frame, the segmentation may be propagated to future or subsequent frames in the video sequence.
  • a sliding window approach may be employed, where each window comprises or is associated with a local classifier that integrates color and shape information from the previous frame, e.g., a color model and a shape prediction, referred to as “priors”, to classify pixels covered by the classifier as foreground or background pixels.
  • Classification results from individual local classifiers may then be combined to form an accurate feature map, and a binary segmentation of the image performed based on the feature map. This process may iterate until the segmentation contour converges. Note that in some embodiments, the iterations for each window may be terminated as each window converges.
  • FIG. 3 illustrates an exemplary video sequence, specifically, frames 1 through 5 , where a segmentation has been performed, e.g., manually, on the first image (frame 1 ) of the sequence, as illustrated by the binary mask associated with the first image, where the white region of the mask corresponds to the foreground and the black region corresponds to the background.
  • Below frames 2 through 5 are shown corresponding video images where respective masks have been applied to each image to remove all background image information, leaving only the foreground object of each image.
  • the segmentation of each image (into foreground and background portions) upon which such masking is based may be determined automatically from previous segmentation information, e.g., from the segmentation of frame 1 .
  • each frame's segmentation contour i.e., the boundary between the background and the foreground, may determined based on that of the previous frame.
  • FIG. 4 is a high level diagram of an exemplary single frame propagation technique illustrating key concepts of the present invention, according to one embodiment.
  • a user-provided segmentation of a first frame (frame i) e.g., a segmentation contour of the image
  • frame i+1 a segmentation shape prediction
  • FIG. 4 a segmentation shape prediction for a current image (frame i+1) via a plurality of local classifiers, represented in FIG.
  • classifiers or windows may be used to characterize the images' color and shape attributes in local regions, specifically along the contour, which may then be used to generate multiple local feature maps that together compose a feature map of the image, also referred to as a probability map (with respect to foreground and background pixel classification), from which may be determined the contour (segmentation) of the current image or frame, as will be described in more detail below.
  • this single-frame approach may include an iterative component, as indicated in FIG. 5 , where, from a contour of a frame i, denoted as C i , a shape prediction is generated and used to create a feature map estimation, which in turn is used to compute a segmentation (contour) of the current frame i+1.
  • the feature map estimation and segmentation may be iterated to refine the computed contour. For example, the computed contour from one iteration may be used to generate a refined feature map estimation, which may then be used to determine a refined segmentation or contour. This iteration may be repeated until some convergence condition is met, e.g., until the differences between successive computed contours is below some specified threshold.
  • the single-frame-propagation model which may be considered to be the fundamental building block of the system, transfers or transforms an object contour C i in frame i to an object contour C i+1 in frame i+1.
  • the basic idea is to perform a rough shape prediction to generate a predicted contour, and then refine the contour around the predicted shape.
  • the process may involve several separate steps.
  • the initial contour C i may be transformed by SIFT key point matching and optical flow.
  • a set of local classifiers may be built or constructed along the contour to separate foreground/background pixels, where the classifiers integrate both color and shape information, e.g., of the local region of the classifier, to characterize or specify the contour in that region.
  • the local classification results may then be combined to generate an accurate feature map of the object in frame i+1, which may be followed by a binary segmentation. This estimation-segmentation step may be repeated several times until C i+1 converges.
  • segmentation information from one frame may be used to determine segmentation for multiple subsequent frames.
  • various techniques may be used to robustly track the windows/classifiers as they are propagated through successive frames.
  • An exemplary embodiment of such a multi-frame propagation model is illustrated in FIG. 6 , where, as may be seen, a segmentation of frame 1 (or i), represented by the mask of frame 1 in the figure, may be used to propagate a segmentation contour from frame 1 to a subsequent frame 2 (or i+1), similar to the single-frame approach described above with respect to FIG.
  • this segmentation information may be used to determine the segmentation (contour) of the subsequent frame, e.g., frame 3 (i+2), and so on.
  • information from the initial frame may also be used, e.g., a color map or other segmentation-related information, as will be discussed in more detail below.
  • FIG. 7 Flowchart of a Method for Performing Automatic Image Segmentation in a Video Sequence
  • FIG. 7 is a flowchart illustrating a method for automatically determining segmentation in a digital video sequence.
  • the method shown in FIG. 7 may be used in conjunction with embodiments of the computer system shown in FIG. 1 , among other devices.
  • some of the method elements shown may be performed concurrently, in a different order than shown, or may be omitted. Additional method elements may also be performed as desired. Any of the method elements described may be performed automatically (i.e., without user intervention). As shown, this method may operate as follows.
  • a segmentation shape prediction and a segmentation color model for a current image (e.g., a first image) of a video sequence may be determined based on existing segmentation information for at least one previous image of the video sequence. For example, in one embodiment, a user may manually segment the current image into a foreground and a background, storing the segmentation information for this current image, including a segmentation contour that divides the background from foreground, e.g., a foreground object, in the image.
  • the determination of the shaped prediction and color model may be performed via any of a variety of techniques, as desired.
  • scale invariant feature transform (SIFT) techniques may be employed to generate an estimate or rough version of the segmentation contour for the current image based on the at least one previous image of the sequence, i.e., based on the pre-existing segmentation contour.
  • SIFT key points are reliable features for consecutive frames in videos. By matching the SIFT key points of the previous image/frame with corresponding key points in the current image/frame, one can determine a good initial guess of the contour in the current (or new) frame.
  • the method may search in the current frame for a best match for each (SIFT) key point inside the foreground object of the previous frame.
  • SIFT a affine transform
  • an affine transform e.g., specifying translation, rotation, shearing, and possibly scaling
  • FIG. 8 shows an example of matched key points (i.e., feature points) in consecutive video frames.
  • each key point x in frame i corresponds to a key point in frame i+1.
  • the search range may be limited to a region enclosing the contour, e.g., a rectangle slightly larger than the bounding box of the contour, as indicated by the dashed box surrounding the object bounded by the contour C i .
  • outliers may be omitted when fitting these points.
  • FIG. 9 illustrates such key points and their matches or correspondences in two consecutive frames of the exemplary video sequence introduced in FIG. 3 (and also used in FIGS. 4 and 6 ). Note that because the image changes between two consecutive frames are small, detecting and correlating the key points will generally be straightforward and quite reliable. Thus, the affine transform determined based on these points may provide ready means for generating a rough estimate of the initial contour, e.g., by propagating the contour via the transform to the next frame.
  • the initial contour may be transformed to generate a rough estimate or predicted shape of the contour for the subsequent frame.
  • a plurality of local classifiers may be constructed along the contour and used to perform operations with respect to the contour.
  • a sliding window approach may be employed, where each classifier, whose center point lies on the contour, defines and operates on a local region around a respective contour point (the classifier's center), integrating color and shape information from the previous frame, e.g., a color model and a shape prediction, and determining the predicted contour accordingly.
  • the classifiers represented in FIG.
  • each classifier box or window preferably overlaps at least two other classifiers.
  • the respective region of each local classifier of the plurality of local classifiers overlaps the respective regions of at least two other local classifiers of the plurality of local classifiers
  • the shape alignment process may operate to roughly align the classifier windows with the foreground object in frame i+1.
  • determining the segmentation shape prediction and the segmentation color model may include constructing a plurality of local classifiers for the at least one previous image, where each local classifier includes a respective region of the at least one previous image that contains a respective portion of a shape contour of the at least one previous image, and where the plurality of local classifiers cover the shape contour of the at least one previous image. Then, for each local classifier of the plurality of classifiers, a local segmentation shape prediction for the current image may be generated based on the respective portion of the shape contour of the at least one previous image contained in the local classifier.
  • generating a local segmentation shape prediction based on the respective portion of the shape contour may include generating an initial local segmentation shape prediction via scale invariant feature transform (SIFT) applied to a plurality of key points in the respective region, and generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour.
  • SIFT scale invariant feature transform
  • generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour may include determining a local average flow vector based on optical flow of foreground pixels in the respective region, and applying the local average flow vector to the points along the respective portion of the shape contour to generate the local segmentation shape prediction.
  • a local segmentation color model may be generated based at least on color information for the respective region of the at least one previous image included in the local classifier.
  • a local average flow inside the contour may be used.
  • x be a point on the transformed contour C*.
  • is the inside region of C*
  • N x is a local classifier or window centered at x.
  • the flow vector applied to x is the average of the flow vectors of all points that are in both the inner region ⁇ and the classifier window, i.e., that are in the intersection of these two point sets.
  • This regional or local average optical flow is much more robust than that generated from single points, primarily due to the fact that the object's motion is generally locally smooth. By incorporating local averaged optical flow into the process, a more accurate and robust estimated contour may be generated.
  • FIG. 11 illustrates a first frame (labeled frame 1 ) with user provided segmentation indicated by a white contour line around the foreground object, and a second frame (labeled frame 2 ) with the contour after alignment and optical flow. Note that the contour in frame 2 , which corresponds to frame i+1 of FIG.
  • contour 4 is very similar to the original contour (of frame 1 ), but is still not perfect, being an estimate or prediction.
  • this contour specifically, the contour segments composing the contour, may be used by the classifiers in determining an even better contour, as will now be described.
  • local classifiers may comprise a set of sliding windows along the contour.
  • the typical size of a classifier box or window may vary from 50 ⁇ 50 to 70 ⁇ 70 pixels in size, although any other sizes may be used as desired.
  • the centers of these windows may be equally spaced sample points along the contour C i , as shown in FIG. 12 (note that for illustration only a few non-overlapping windows are shown).
  • the number of windows may be set such that each point near the contour is covered by at least two windows. As described above, the centers of these overlapping windows may be transformed and (average optically) flowed into the next frame together with the contour.
  • pairs of these two sets of classifiers may referred to as first and second classifiers for convenience.
  • a plurality of local classifiers for the current image corresponding to the plurality of local classifiers for the at least one previous image may be generated by applying the average flow vector to the plurality of local classifiers for the at least one previous image, wherein each local classifier for the current image comprises a respective region of the current image that contains a respective portion of a shape contour of the current image, and wherein the plurality of local classifiers of the current image cover the shape contour of the current image.
  • the pixels in W k i+1 may be classified as foreground or background pixels based on their strong temporal correlation in color and shape.
  • the classification of pixels of frame i may be used to classify those of frame i+1.
  • FIG. 13 illustrates color and shape integration with adaptive weights, according to one embodiment.
  • a color model and predicted shape (shape prior) for a particular local classifier are combined based on confidence levels pertaining to their respective background or foreground characterizations to generate a resultant feature map for the local region of the classifier. For example, as FIG.
  • this approach may be considered to be a type of fuzzy logic pixel classification scheme, where color models and predicted shapes are used as appropriate to classify pixels as foreground or background pixels. More details regarding this process are provided below.
  • GMM Gaussian Mixture Model
  • pixels near the estimated contour are more difficult to classify as foreground or background pixels because the estimated or predicted contour almost certainly has come error, and so pixels near the estimated contour on the FG side may actually be on the BG side of the actual (unknown) boundary, and vice versa.
  • FIG. 14 illustrates regions for correlated classifiers, e.g., first and second classifiers, W k i and W k i+1 , where each region is divided into respective foreground and background sub-regions. More specifically, the first classifier is divided into a foreground F 1 and a background B 1 , and the second classifier is divided into a foreground F 2 and a background B 2 , as shown.
  • the sampled pixels from the first classifier may be denoted by ⁇ F 1 ; B 1 ⁇ .
  • colors in the second classifier may also be sampled.
  • d x >max ⁇ d x ⁇ /2 ⁇ , and B 2 ⁇ x
  • the tentative sampling in W k i+1 may be inaccurate.
  • the pixels demarcated as ⁇ F 2 , B 2 ⁇ may both be on the foreground or the background side of the region, i.e., the contour prediction the pixels are segregated by may be so inaccurate that the actual contour is not even in the region, in which case the ⁇ F 2 , B 2 ⁇ pixels should not be used.
  • criteria may be set or specified to determine whether or not to include ⁇ F 2 , B 2 ⁇ in the determination of the color model.
  • Two candidate color models may be built:
  • 6-components e.g., 3 for foreground colors and 3 for background colors
  • the final foreground probabilities may be normalized via a log scale, i.e.:
  • P C ⁇ ( x ) log ⁇ ⁇ P B ⁇ ( x ) log ⁇ ⁇ P F ⁇ ( x ) + log ⁇ ⁇ P B ⁇ ( x ) , x ⁇ W k i + 1 .
  • FIG. 15 illustrates exemplary differences resulting from the use of the two candidate color models, e.g., the mixed color model, based on pixels from both classifiers ⁇ F 1 , B 1 ; F 2 , B 2 ⁇ , and the simple color model, based only on pixels from the first classifiers ⁇ F 1 , B 1 ⁇ .
  • the classifier regions of FIG. 14 are used, where as may be seen, the probability map generated by the mixed model is significantly less ambiguous than that generated by the simple model, i.e., the foreground and background are more clearly separated, and also correspond more closely to the second image.
  • the mixed color model should be used.
  • the second frame doesn't have a foreground portion, but the predicted contour still indicates one.
  • the probability map using the mixed color model doesn't correspond with the second image (because the foreground changed so much), whereas the probability map using the simple color model correctly reflects the absence of foreground pixels, and so in this case, the simple color model should be used.
  • generating a local segmentation color model may include generating a local segmentation simple color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image, and generating a local segmentation mixed color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image and color information for the respective region of the current image included in the local classifier for the current image. Discriminability of the local segmentation mixed color model and the local segmentation simple color model may be determined.
  • Generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier may then include selecting the local segmentation simple color model as the local segmentation color model if the local segmentation simple color model has greater discriminability than the local segmentation mixed color model, and selecting the local segmentation mixed color model as the local segmentation color model if the local segmentation mixed color model has greater discriminability than the local segmentation simple color model.
  • a shape prior i.e., a predicted shape
  • the contribution from the predicted shape may be based on the discriminability of the color model, where if the color model makes a clear distinction between foreground colors and background colors, the color model is relied on to classify the pixels of the region, and if the color model does not make a clear distinction, the shape prior is relied on to classify the pixels, with intermediate situations addressed by weights applied to each, e.g., where the weights sum to some normalized value, e.g., 1.
  • the weights are coefficients in a linear sum of the color and shape contributions. Note, however, that in other embodiments, the shape and color contributions may be determined by a non-linear combination.
  • FIG. 16 illustrates shape prediction confidence, according to one embodiment. More specifically, FIG. 16 illustrates an exemplary relationship between the confidence of pixel classifications based on the predicted contour and the contribution of the predicted shape probability map to the integrated probability map discussed above, e.g., in a weighted linear sum of the color and shape contributions.
  • the weight applied the shape contribution represented by the P s axis, ranges from zero to 1, i.e., ranging from no contribution to being the only contribution, depending on the distance of the pixel from the estimated contour, represented by the d axis.
  • the contributions from the color model and the predicted shape may be complementary, such that as one increases, the other decreases.
  • a d value of 0 means that the pixel is (at least approximately) on the contour, and thus there may be maximum uncertainly as to which side (FG or BG) of the (actual) contour the pixel is on based on the predicted shape, and so the weight applied to the shape prediction will be zero.
  • the classification of pixels with positions sufficiently removed from 0 i.e., deep in the FG or BG portions of the region, may be reliably made via the predicted shape, giving a weight of 1.
  • M k be the binary (foreground) mask enclosed by C i+1 , i.e.:
  • a shape confidence term (weight) P S may be defined as:
  • is the parameter controlling the blurry width of the shape, i.e., an uncertainty band with respect to the predicted shape, i.e., the estimated contour, where, as noted above, ⁇ denotes the discriminability of the color model.
  • depends on the separation or discriminability of foreground and background in the color model, and this value is used to blur the contour of the predicted shape, such that the more reliable the color model is, the less clear the predicted shape is regarding the contour.
  • the predicted shape is increasingly relied on to classify the pixels as FG or BG pixels, and conversely, for pixels increasingly near the estimated contour, the color map is increasingly relied upon, where the width and rate of the switchover is specified by ⁇ , as FIG. 16 shows.
  • the width and rate of the switchover
  • FIG. 17 illustrates shape prediction constraints based on discriminativity of the color model, according to one embodiment.
  • the blurry width c is related to the discriminativity of the color model.
  • c is large and the shape constraint is loose, i.e., the blurred band in the predicted shape probability map is wider;
  • FG and BG colors are mixed, c becomes small and the shape constraint is tight, i.e., the blurred band in the predicted shape probability map is thinner.
  • the classification error e is the sum of misclassifications, weighted by the distance to the contour:
  • the color map for frame i+1 may be used to (re)classify the pixels of frame i (whose actual classifications are already known, since that image has already been segmented), and by determining the errors due to the color model, determine the confidence or reliability of the color model, i.e., to determine ⁇ .
  • may be computed therefrom.
  • the minimum discriminability of the color model ⁇ min may correlate with the maximum error with respect to the color model, and may define the point at which the shape prediction is the dominant contributor.
  • FIG. 18 illustrates color and shape integration, according to one embodiment. More specifically, FIG. 18 illustrates exemplary color and shape probability maps (i.e., feature maps), P c and P s , and a corresponding integrated probability map P int for a classifier (region). Note that the integrated probability or feature map is a more accurate and precise estimate of the contour than either of the color or shape maps. Thus, by using embodiments of the above techniques, each classifier may determine a probability or feature map for a respective portion of the image proximate to the estimated contour.
  • exemplary color and shape probability maps i.e., feature maps
  • P c and P s i.e., feature maps
  • P int integrated probability map
  • the probabilities (i.e., probability or feature maps) in all local windows, i.e., from all local classifiers may be combined to form a combined feature map.
  • a local feature map estimation may be generated based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, where the local feature map estimation classifies pixels in the respective region as background or foreground pixels. Then, a feature map estimation for the current image may be generated by combining the local feature map estimations.
  • a pixel is covered by multiple windows, its respective probability (classification) may be determined from a weighted linear combination of values in different windows, i.e., from different classifiers, e.g.,:
  • a combined probability or feature map for the image (e.g., of frame i+1) may be determined using both color models and shape predictions for each of a plurality of local classifiers.
  • a plurality of local feature maps e.g., foreground masks, may be stitched together to form a global or combined feature map or mask.
  • a segmentation of the current image may be automatically generated based on a weighted combination of the segmentation shape prediction and the segmentation color model, as described below.
  • the combined feature (probability) map may be used to segment the image (into foreground and background portions).
  • the combined feature map i.e., the generated feature map estimation for the current image
  • the probability values may be set as data cost, after which a GAC (Geodesic Active Contour) algorithm may be performed to further regularize the boundary, e.g., implemented by level sets.
  • GAC Gateodesic Active Contour
  • the local feature maps may each be used to perform a local segmentation for each classifier window, after which these local segmentations (segmented image portions) may be stitched together to form the segmented image.
  • portions of the above techniques may be repeated in an iterative manner to further refine the segmentation. For example, using the segmentation boundary as an initial contour, the feature map estimation and segmentation process described above may be repeated to produce a more accurate result.
  • the windows or classifier regions may be fixed, i.e., only the contour inside (the local foreground portion of the classifier region) may be updated. For each iteration, different color samples may be selected, and the current contour may be used as the shape prior or predicted shape. Local results may then be combined for segmentation. The iterations may terminate when the local classifier's contour does not change any more, e.g., within some specified tolerance, e.g., up to a few (10-20) pixels.
  • FIG. 19 illustrates contour iteration with respect to feature map estimation and segmentation, according to one embodiment.
  • the original (estimated) contour which passes through the center point of the classifier region, is moved to the right of the center. This contour may then be used for the next iteration, i.e., for the next feature map estimation and segmentation.
  • the method may include iteratively performing the above-described determining the segmentation shape prediction and segmentation color model and automatically generating a segmentation of the current image, until the shape contour for the current image converges, where the segmentation of the current image for each iteration is used as the segmentation information for the next iteration.
  • the converged classifiers may be marked, and only the unmarked classifiers may be updated in future iterations.
  • the iterations may be performed until all classifiers converge, or until it is determined that convergence will not occur, in which case the user may intervene, e.g., by manually segmenting the image, as will be discussed below in more detail.
  • the segmentation of the current image may be stored, e.g., in a memory medium of the computer system 100 , and/or a memory medium coupled to the computer system, e.g., over a network, e.g., a SAN.
  • the method may then repeat the above-described method elements for subsequent images or frames of the video sequence, as described below in more detail.
  • the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, the automatically generating a segmentation of the current image, and the storing of the segmentation of the current image may be repeated for one or more contiguous images in the video sequence.
  • storing the segmentation of the current image may include storing the information describing or specifying the segmentation of the image, e.g., for subsequent use in processing the image, e.g., for special effects, etc.
  • the segmented image itself may be stored.
  • a simple concatenation of the single-frame-propagation techniques described above may result in significant inaccuracies, since the error accumulates from frame to frame.
  • Two approaches to effectively control or ameliorate the error divergence are described below.
  • the first approach is to constantly rely on the color samples in the first frame.
  • this approach may be extended and modified to form a multi-frame propagation process where color information for an initial frame is used to automatically perform segmentation for multiple subsequent frames.
  • FIG. 20 illustrates multi-frame propagation of segmentation using a color model of an initial frame, according to one embodiment.
  • a first frame C 1 is used to generate a sequence of subsequent contours or segmentations, specifically, for subsequent frames C 2 -Cn.
  • the color model for the initial frame (C 1 ) is used for each of the subsequent frames, while shape information, e.g., a shape prediction, for each frame is used for the next frame.
  • shape information e.g., a shape prediction
  • the local classifier may be repositioned onto the shape contour.
  • This repositioning may include determining a normal distance from the local classifier's center to the shape contour, and moving the local classifier onto the shape contour based at least in part on the normal distance.
  • the determining a normal distance and the moving the local classifier may ameliorate propagation and divergence of errors.
  • local averages of the normal distance may be used to reposition each window.
  • FIG. 21 illustrates multi-frame propagation of segmentation using a feedback correction approach with respect to window/classifier positions, according to one embodiment. More specifically, FIG. 21 illustrates an exemplary embodiment of such a process, where, as may be seen, initial window positions are indicated in element (a) where the contour passes through the center points of multiple classifier windows. This may represent the situation resulting from the rough alignment of the classifiers (and respective contour segments) via shape prediction. In element (b), a new boundary or contour is formed upon convergence of the iterative refinement process.
  • each window center its displacement to the nearest point on the new contour or boundary may be determined.
  • the normal displacement (vector) from each classifier center point to the new contour may be determined.
  • the classifier window centers may be moved based on the displacement.
  • the classifier window centers may be moved according to an average displacement around the region, e.g., based on an average of the displacement vectors of neighboring or nearby classifiers, e.g., those that overlap the current classifier, e.g., vectors for windows i ⁇ 2, i ⁇ 1, i, i+1, and i+1 may be averaged to move window I, or vectors for classifiers within some distance of the current window may be averaged, etc., as desired.
  • the classifier window centers may simply be moved to the contour based on their respective displacements.
  • the boundary or contour and the classifier window centers may be moved or propagated to the next frame via shape prediction, as described above. Thus, once the contour or boundary is moved, the windows centers may subsequently be moved to (or near) the contour.
  • one or both of the above approaches to error confinement may be used to limit or ameliorate the propagation and divergence of errors in the automatic segmentation process, although it should be noted that any other error management techniques may be used as desired.
  • GUI graphical user interface
  • the user may edit the segmentation results, e.g., in a forward progressive fashion.
  • the method may automatically propagate the segmentation to the next N frames, and the user may play the video forward to check the results until an error is found. Two modes of user correction are now presented.
  • the user may correct only a small part of the contour. In other words, only a limited number of windows may be manually updated. The correction may then propagate to the future frames.
  • the user may manually correct the current frame, and the current frame may be set as the first or initial frame for the automatic segmentation process, and the method proceeds from this frame, propagating forward until another error occurs.
  • the entire video sequence is segmented when the last frame is reached.
  • FIG. 22 illustrates user interaction to correct or reset multi-frame propagation of segmentation in a video sequence, according to one embodiment, where the top sequence of frames ( 1 through 5 ) are automatically segmented based on initial frame 1 , but where an error is detected in frame 3 and corrected by the user. Then, as FIG. 22 indicates, corrected frame 3 is reset or designated as an initial frame for continued (recomputed) segmentation of successive frames ( 4 through 7 ).
  • performing the above-described determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, automatically generating a segmentation of the current image, and storing the segmentation of the current image, for one or more contiguous images in the video sequence may include performing the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, automatically generating a segmentation of the current image, and storing the segmentation of the current image, for a first plurality of contiguous images in the video sequence, including an ultimate (i.e., last) image in the first plurality of contiguous images, then editing segmentation of the ultimate image in response to input, thereby generating edited segmentation information, then performing the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, automatically generating a segmentation of the current image, and storing the segmentation of the current image, for a second plurality of contiguous
  • the techniques may also or instead be propagated in the reverse direction.
  • the techniques described herein are agnostic or generic with respect to the particular direction of the video sequence.
  • this aspect may be used to possibly improve the segmentation process.
  • embodiments of the methods described above may be performed on a video sequence (possibly a small sub-sequence within the larger video sequence) from either end, e.g., concurrently and/or sequentially, e.g., until the contours for each image converge.
  • the user may manually segment two key frames bounding a sequence, then propagate inward from both ends, possibly stopping in the middle (at least temporarily) to reconcile competing contours for that image, then optionally continuing to opposite ends, refining the previously computed segmentation (by the opposite propagation).
  • Other variations of this bi-directional technique are also contemplated.
  • various embodiments of the above techniques may be used to automatically propagate foreground/background image segmentation in a video sequence.
  • FIGS. 23 and 24 illustrate exemplary video sequences resulting from application of embodiments of the above techniques, where original images of a video sequence are presented vertically on the left (top to bottom), corresponding segmentation masks or feature maps are presented in the middle of the figures, and corresponding images with segmented foreground composited on blue backgrounds are presented vertically on the right. As may be seen, in both sequences, the first (top) segmentation mask is provided by the user. Note that in the sequence of FIG. 23 , every 10 th frame is shown, as indicated by the frame numbers labeling each original frame image.
  • various embodiments of the systems and methods disclosed herein may be used to automatically perform image segmentation in a digital video image sequence.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Image Analysis (AREA)

Abstract

A method, system, and computer-readable storage medium for automatic segmentation of a video sequence. A segmentation shape prediction and a segmentation color model are determined for a current image of a video sequence based on existing segmentation information for at least one previous image of the video sequence. A segmentation of the current image is automatically generated based on a weighted combination of the segmentation shape prediction and the segmentation color model. The segmentation of the current image is stored in a memory medium.

Description

PRIORITY DATA
This application claims benefit of priority to U.S. Provisional Application Ser. No. 61/091,242 titled “Automatic Video Image Segmentation”, filed Aug. 22, 2008, whose inventors are Jue Wang and Xue Bai, and which is hereby incorporated by reference in its entirety.
BACKGROUND
1. Field of the Invention
The present invention is directed generally to digital image processing, and more particularly to automatic segmentation of images in a video sequence.
2. Description of the Related Art
Digital images may include raster graphics, vector graphics, or a combination thereof. Raster graphics data (also referred to herein as bitmaps) may be stored and manipulated as a grid of individual picture elements called pixels. A bitmap may be characterized by its width and height in pixels and also by the number of bits per pixel. Commonly, a color bitmap defined in the RGB (red, green blue) color space may comprise between one and eight bits per pixel for each of the red, green, and blue channels. An alpha channel may be used to store additional data such as per-pixel transparency values. Vector graphics data may be stored and manipulated as one or more geometric objects built with geometric primitives. The geometric primitives (e.g., points, lines, polygons, Bézier curves, and text characters) may be based upon mathematical equations to represent parts of digital images.
Digital image processing is the process of analyzing and/or modifying digital images using a computing device, e.g., a computer system. Using specialized software programs, digital images may be manipulated and transformed in a variety of ways.
There are many digital video applications that require segmentation of each video image or frame, e.g., into a foreground image or object/region of interest and a background. Prior art approaches to such segmentation involve manually segmenting each frame image using various image editing tools. However, such manual segmentation is time-consuming, tedious, and error prone.
SUMMARY
Various embodiments of systems, methods, and computer-readable storage media for performing automatic segmentation of images in a video sequence are presented.
First, a segmentation shape prediction and a segmentation color model for a current image (e.g., a first image) of a video sequence may be determined based on existing segmentation information for at least one previous image of the video sequence. For example, in one embodiment, a user may manually segment the current image into a foreground and a background, storing the segmentation information for this current image, including a segmentation contour that divides the background from foreground, e.g., a foreground object, in the image.
The determination of the shaped prediction and color model may be performed via any of a variety of techniques, as desired. For example, regarding shape prediction, in one embodiment, scale invariant feature transform (SIFT) techniques may be employed to generate an estimate or rough version of the segmentation contour for the current image based on the at least one previous image of the sequence, i.e., based on the pre-existing segmentation contour. SIFT key points are reliable features for consecutive frames in videos. By matching the SIFT key points of the previous image/frame with corresponding key points in the current image/frame, one can determine a good initial guess of the contour in the current (or new) frame. Thus, once the affine transform has been determined based on the matching key points in the two frames, the initial contour may be transformed to generate a rough estimate or predicted shape of the contour for the subsequent frame. In some embodiments, a plurality of local classifiers may be constructed along the contour and used to perform operations with respect to the contour. For example, in some embodiments, a sliding window approach may be employed, where each classifier, whose center point lies on the contour, defines and operates on a local region around a respective contour point (the classifier's center), integrating color and shape information from the previous frame, e.g., a color model and a shape prediction, and determining the predicted contour accordingly. Thus, the shape alignment process may operate to roughly align the classifier windows with the foreground object in frame i+1.
More specifically, in some embodiments, generating a local segmentation shape prediction based on the respective portion of the shape contour may include generating an initial local segmentation shape prediction via scale invariant feature transform (SIFT) applied to a plurality of key points in the respective region, and generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour. In one embodiment, generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour may include determining a local average flow vector based on optical flow of foreground pixels in the respective region, and applying the local average flow vector to the points along the respective portion of the shape contour to generate the local segmentation shape prediction. A local segmentation color model may be generated based at least on color information for the respective region of the at least one previous image included in the local classifier. Thus, the use of local classifiers to characterize and operate on local regions of the image may significantly enhance the accuracy and results of segmentation, particularly regarding images with complex foreground objects and/or backgrounds.
While applying the transform to each point on the contour (or some specified subset of such points, such as equally spaced sample points along the contour) will generate a rough estimate of the contour that approximately aligns the contour to the image of the subsequent frame, this transformation generally captures the object's principle rigid motion between the two frames, and thus may generally omit motion effects specific to local motion of parts of the object. To determine a better prediction of the contour, optical flow of contour pixels between the transformed frame and the next frame may be computed. However, due to the unreliability of optical flow on the boundary, e.g., where occlusion occurs, directly adding the flow vector to the contour points, i.e., at the pixel level, may produce erratic results. Thus, in on embodiment, rather than computing the optical flow based on the contour points themselves (using the center point per classifier), a local average flow inside the contour may be used. By incorporating local averaged optical flow into the process, a more accurate and robust estimated contour may be generated.
Thus, from these two steps (transformation/alignment plus average optical flow), one may generate a prediction of the contour, or, more accurately, a plurality of predicted or estimated contour portions or segments, each covered by and associated with a respective classifier. This predicted or estimated contour may then be used as a shape prior (shape prediction) and may specify positions of the local classifiers.
One approach to calculating the foreground probabilities for the pixels in a propagated classifier is via a Gaussian Mixture Model (GMM). In this approach, all the pixels in the local region or window of the second classifier are sampled except for a narrow band around the contour, which in some embodiments may be defined by (|dx|<Δ), where Δ is the width of an uncertainty band in the first classifier, and where dx is the maximum distance of a pixel x from the contour in the classifier. In other words, pixels near the estimated contour are more difficult to classify as foreground or background pixels because the estimated or predicted contour almost certainly has come error, and so pixels near the estimated contour on the FG side may actually be on the BG side of the actual (unknown) boundary, and vice versa.
In some embodiments, generating a local segmentation color model may include generating a local segmentation simple color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image, and generating a local segmentation mixed color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image and color information for the respective region of the current image included in the local classifier for the current image. Discriminability of the local segmentation mixed color model and the local segmentation simple color model may be determined. Generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier may then include selecting the local segmentation simple color model as the local segmentation color model if the local segmentation simple color model has greater discriminability than the local segmentation mixed color model, and selecting the local segmentation mixed color model as the local segmentation color model if the local segmentation mixed color model has greater discriminability than the local segmentation simple color model.
As discussed above, in addition to the color model, a shape prior, i.e., a predicted shape, may also be used to generate the probability or feature map for a classifier region. More specifically, the contribution from the predicted shape (as part of a weighted sum) may be based on the discriminability of the color model, where if the color model makes a clear distinction between foreground colors and background colors, the color model is relied on to classify the pixels of the region, and if the color model does not make a clear distinction, the shape prior is relied on to classify the pixels, with intermediate situations addressed by weights applied to each, e.g., where the weights sum to some normalized value, e.g., 1. In other words, in some embodiments, the weights are coefficients in a linear sum of the color and shape contributions. Note, however, that in other embodiments, the shape and color contributions may be determined by a non-linear combination.
Once the color map for frame i+1 is determined (as described above), it may be used to (re)classify the pixels of frame i (whose actual classifications are already known, since that image has already been segmented), and by determining the errors due to the color model, determine the confidence or reliability of the color model. By using embodiments of the above techniques, each classifier may determine a probability or feature map for a respective portion of the image proximate to the estimated contour.
In one embodiment, the probabilities (i.e., probability or feature maps) in all local windows, i.e., from all local classifiers, may be combined to form a combined feature map. For example, for each local classifier of the plurality of classifiers, a local feature map estimation may be generated based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, where the local feature map estimation classifies pixels in the respective region as background or foreground pixels. Then, a feature map estimation for the current image may be generated by combining the local feature map estimations. A combined probability or feature map for the image (e.g., of frame i+1) may be determined using both color models and shape predictions for each of a plurality of local classifiers. Said another way, a plurality of local feature maps, e.g., foreground masks, may be stitched together to form a global or combined feature map or mask.
A segmentation of the current image may be automatically generated based on a weighted combination of the segmentation shape prediction and the segmentation color model. In one embodiment, the combined feature (probability) map may be used to segment the image (into foreground and background portions). For example, in one embodiment, the combined feature map (i.e., the generated feature map estimation for the current image) may be used to segment the image using an image processing algorithm such as Graph Cut, where the probability values may be set as data cost, after which a GAC (Geodesic Active Contour) algorithm may be performed to further regularize the boundary, e.g., implemented by level sets. Note, however, that any other algorithms and/or tools may be used as desired. In an alternative embodiment, rather than generating a combined feature map, then segmenting the image according to the combined feature map, the local feature maps may each be used to perform a local segmentation for each classifier window, after which these local segmentations (segmented image portions) may be stitched together to form the segmented image.
The segmentation of the current image may be stored, e.g., in a memory medium of the computer system, and/or a memory medium coupled to the computer system, e.g., over a network, e.g., a SAN. The method may then repeat the above-described method elements for subsequent images or frames of the video sequence, as described below in more detail. In other words, the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, the automatically generating a segmentation of the current image, and the storing of the segmentation of the current image, may be repeated for one or more contiguous images in the video sequence.
Thus, various embodiments of the systems and methods disclosed herein may be used to automatically perform image segmentation in a digital video image sequence.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram of an exemplary system configured to implement embodiments of the present invention;
FIG. 2 illustrates an exemplary video image processing module, according to one embodiment;
FIG. 3 illustrates an exemplary video sequence with segmentation/masking, according to one embodiment;
FIG. 4 is a high level diagram of an exemplary single frame propagation approach to automatic image segmentation, according to one embodiment;
FIG. 5 illustrates an iterative aspect of the single frame propagation approach of FIG. 4, according to one embodiment;
FIG. 6 is a high level diagram of an exemplary multi-frame propagation approach to automatic image segmentation, according to one embodiment;
FIG. 7 is a flowchart illustrating a method for performing automatic segmentation of images in a video sequence, according to one embodiment;
FIGS. 8 and 9 illustrate scale invariant feature transform (SIFT) of key points in consecutive video frames, according to one embodiment;
FIG. 10 illustrates optical flow of a contour point in a video frame, according to one embodiment;
FIG. 11 illustrates prediction of a segmentation contour in successive video frames, according to one embodiment;
FIG. 12 illustrates local classifiers in successive video frames, according to one embodiment;
FIG. 13 illustrates local color and shape integration with adaptive weights, according to one embodiment;
FIG. 14 illustrates candidate local color models, according to one embodiment;
FIG. 15 illustrates use and results of the two candidate color models of FIG. 14, according to one embodiment;
FIG. 16 illustrates shape prediction confidence, according to one embodiment;
FIG. 17 illustrates shape prediction constraints based on discriminativity of the color model, according to one embodiment;
FIG. 18 illustrates color and shape integration, according to one embodiment;
FIG. 19 illustrates contour iteration with respect to feature map estimation and segmentation, according to one embodiment;
FIG. 20 illustrates multi-frame propagation of segmentation using a color model of an initial frame, according to one embodiment;
FIG. 21 illustrates multi-frame propagation of segmentation using a feedback correction approach with respect to window/classifier positions, according to one embodiment;
FIG. 22 illustrates user interaction to correct or reset multi-frame propagation of segmentation in a video sequence, according to one embodiment; and
FIGS. 23 and 24 illustrate exemplary video sequences resulting from application of embodiments of the method of FIG. 7.
While the invention is susceptible to various modifications and alternative forms, specific embodiments are shown by way of example in the drawings and are herein described in detail. It should be understood, however, that drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the invention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of the present invention as defined by the appended claims.
DETAILED DESCRIPTION OF EMBODIMENTS
Embodiments of the systems and methods described herein may be used to automatically perform video image segmentation, e.g., of a region or object of interest, e.g., a foreground object, in a digital video sequence. More specifically, embodiments of the systems and methods disclosed herein may be used to analyze sequential digital video images or frames, and to propagate an initial image segmentation of a frame to one or more subsequent frames, e.g., to automatically generate a sequence of foreground masks for corresponding video frames in a video sequence, based on an initial pre-existing segmentation or mask for an initial or key frame in the sequence. Examples of applications for such masks include, but are not limited to, special effects in digital films, e.g., removing or replacing backgrounds, applying effects to different image layers, and so forth, as well as image decomposition and analysis, e.g., for scientific or security applications, e.g., monitoring, surveillance, face recognition, etc.
In the following detailed description, numerous specific details are set forth to provide a thorough understanding of claimed subject matter. However, it will be understood by those skilled in the art that claimed subject matter may be practiced without these specific details. In other instances, methods, apparatuses or systems that would be known by one of ordinary skill have not been described in detail so as not to obscure claimed subject matter. Some portions of the detailed description are presented in terms of algorithms or symbolic representations of operations on data bits or binary digital signals stored within a computing system memory, such as a computer memory. These algorithmic descriptions or representations are examples of techniques used by those of ordinary skill in the data processing arts to convey the substance of their work to others skilled in the art. An algorithm is here, and is generally, considered to be a self-consistent sequence of operations or similar processing leading to a desired result. In this context, operations or processing involve physical manipulation of physical quantities. Typically, although not necessarily, such quantities may take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared or otherwise manipulated. It has proven convenient at times, principally for reasons of common usage, to refer to such signals as bits, data, values, elements, symbols, characters, terms, numbers, numerals or the like. It should be understood, however, that all of these and similar terms are to be associated with appropriate physical quantities and are merely convenient labels. Unless specifically stated otherwise, as apparent from the following discussion, it is appreciated that throughout this specification discussions utilizing terms such as “processing,” “computing,” “calculating,” “determining” or the like refer to actions or processes of a computing platform, such as a computer or a similar electronic computing device, that manipulates or transforms data represented as physical electronic or magnetic quantities within memories, registers, or other information storage devices, transmission devices, or display devices of the computing platform.
FIG. 1 is a block diagram illustrating constituent elements of a computer system 100 that is configured to implement embodiments of the systems and methods described herein. The computer system 100 may include one or more processors 110 implemented using any desired architecture or chip set, such as the SPARC™ architecture, an x86-compatible architecture from Intel Corporation or Advanced Micro Devices, or an other architecture or chipset capable of processing data. Any desired operating system(s) may be run on the computer system 100, such as various versions of Unix, Linux, Windows® from Microsoft Corporation, MacOS® from Apple Inc., or any other operating system that enables the operation of software on a hardware platform. The processor(s) 110 may be coupled to one or more of the other illustrated components, such as a memory 120, by at least one communications bus.
In one embodiment, a specialized graphics card or other graphics component 156 may be coupled to the processor(s) 110. The graphics component 156 may include a graphics processing unit (GPU) 170, which in some embodiments may be used to perform at least a portion of the techniques described below. Additionally, the computer system 100 may include one or more imaging devices 152. The one or more imaging devices 152 may include various types of raster-based imaging devices such as monitors and printers. In one embodiment, one or more display devices 152 may be coupled to the graphics component 156 for display of data provided by the graphics component 156.
In one embodiment, program instructions 140 that may be executable by the processor(s) 110 to implement aspects of the techniques described herein may be partly or fully resident within the memory 120 at the computer system 100 at any point in time. The memory 120 may be implemented using any appropriate medium such as any of various types of ROM or RAM (e.g., DRAM, SDRAM, RDRAM, SRAM, etc.), or combinations thereof. The program instructions may also be stored on a storage device 160 accessible from the processor(s) 110. Any of a variety of storage devices 160 may be used to store the program instructions 140 in different embodiments, including any desired type of persistent and/or volatile storage devices, such as individual disks, disk arrays, optical devices (e.g., CD-ROMs, CD-RW drives, DVD-ROMs, DVD-RW drives), flash memory devices, various types of RAM, holographic storage, etc. The storage 160 may be coupled to the processor(s) 110 through one or more storage or I/O interfaces. In some embodiments, the program instructions 140 may be provided to the computer system 100 via any suitable computer-readable storage medium including the memory 120 and storage devices 160 described above.
The computer system 100 may also include one or more additional I/O interfaces, such as interfaces for one or more user input devices 150. In addition, the computer system 100 may include one or more network interfaces 154 providing access to a network. It should be noted that one or more components of the computer system 100 may be located remotely and accessed via the network. The program instructions may be implemented in various embodiments using any desired programming language, scripting language, or combination of programming languages and/or scripting languages, e.g., C, C++, C#, Java™, Perl, etc. The computer system 100 may also include numerous elements not shown in FIG. 1, as illustrated by the ellipsis.
FIG. 2 illustrates an exemplary image analysis module that may implement embodiments of a method for automatically propagating video image segmentation, as described below with reference to FIG. 6. In one embodiment, module 200 may provide a user interface 202 that includes one or more user interface elements via which a user may initiate, interact with, direct, and/or control the method performed by module 200. Module 200 may obtain a set of digital video images 210 and, optionally, user input 212, analyze an initially segmented image or frame and one or more subsequent frames, and propagate the initial image segmentation to the subsequent one or more frames. Segmentation information 204, e.g., information specifying or facilitating segmentation, and may be used to perform the image analysis or processing.
Image analysis module 200 may be implemented as or in a stand-alone application or as a module of or plug-in for a video processing and/or presentation application. Examples of types of applications in which embodiments of module 200 may be implemented may include, but are not limited to, video editing, processing, and/or presentation applications, as well as applications in security or defense, educational, scientific, medical, publishing, digital photography, digital films, games, animation, marketing, and/or other applications in which digital video image editing or presentation may be performed, e.g., where operations are to be directed to different layers of images. Specific examples of applications in which embodiments may be implemented include, but are not limited to, Adobe® Photoshop® and Adobe® Illustrator®. In addition to generating output images 220, module 200 may be used to display, manipulate, modify, and/or store the output images, for example to a memory medium such as a storage device or storage medium.
Overview
One embodiment disclosed herein provides a robust interactive system and method for video object segmentation. Based on pre-existing segmentation information for a previous (or any other) frame in a video sequence, e.g., provided by a user, e.g., via manual segmentation of the previous frame, the segmentation may be propagated to future or subsequent frames in the video sequence. As will be explained below in more detail, in some embodiments, a sliding window approach may be employed, where each window comprises or is associated with a local classifier that integrates color and shape information from the previous frame, e.g., a color model and a shape prediction, referred to as “priors”, to classify pixels covered by the classifier as foreground or background pixels. These two priors may be combined with adaptive weights related to the discriminativity of the color model. Classification results from individual local classifiers may then be combined to form an accurate feature map, and a binary segmentation of the image performed based on the feature map. This process may iterate until the segmentation contour converges. Note that in some embodiments, the iterations for each window may be terminated as each window converges.
FIG. 3 illustrates an exemplary video sequence, specifically, frames 1 through 5, where a segmentation has been performed, e.g., manually, on the first image (frame 1) of the sequence, as illustrated by the binary mask associated with the first image, where the white region of the mask corresponds to the foreground and the black region corresponds to the background. Below frames 2 through 5 are shown corresponding video images where respective masks have been applied to each image to remove all background image information, leaving only the foreground object of each image. In embodiments described herein, the segmentation of each image (into foreground and background portions) upon which such masking is based may be determined automatically from previous segmentation information, e.g., from the segmentation of frame 1.
In one set of embodiments, referred to as one-frame-propagation model embodiments, each frame's segmentation contour, i.e., the boundary between the background and the foreground, may determined based on that of the previous frame. FIG. 4 is a high level diagram of an exemplary single frame propagation technique illustrating key concepts of the present invention, according to one embodiment. As may be seen, in this approach a user-provided segmentation of a first frame (frame i), e.g., a segmentation contour of the image, may be used to determine a segmentation shape prediction (referred to in FIG. 4 as a shape “prior”) for a current image (frame i+1) via a plurality of local classifiers, represented in FIG. 4 by dotted line boxes or windows along the segmentation contours of frames i and i+1. These classifiers or windows may be used to characterize the images' color and shape attributes in local regions, specifically along the contour, which may then be used to generate multiple local feature maps that together compose a feature map of the image, also referred to as a probability map (with respect to foreground and background pixel classification), from which may be determined the contour (segmentation) of the current image or frame, as will be described in more detail below.
In one embodiment, this single-frame approach may include an iterative component, as indicated in FIG. 5, where, from a contour of a frame i, denoted as Ci, a shape prediction is generated and used to create a feature map estimation, which in turn is used to compute a segmentation (contour) of the current frame i+1. Note that in the embodiment of FIG. 5, the feature map estimation and segmentation (computation of contour) may be iterated to refine the computed contour. For example, the computed contour from one iteration may be used to generate a refined feature map estimation, which may then be used to determine a refined segmentation or contour. This iteration may be repeated until some convergence condition is met, e.g., until the differences between successive computed contours is below some specified threshold.
Described in a slightly different manner, the single-frame-propagation model, which may be considered to be the fundamental building block of the system, transfers or transforms an object contour Ci in frame i to an object contour Ci+1 in frame i+1. The basic idea is to perform a rough shape prediction to generate a predicted contour, and then refine the contour around the predicted shape. The process may involve several separate steps. For example, in one embodiment, the initial contour Ci may be transformed by SIFT key point matching and optical flow. A set of local classifiers may be built or constructed along the contour to separate foreground/background pixels, where the classifiers integrate both color and shape information, e.g., of the local region of the classifier, to characterize or specify the contour in that region. The local classification results may then be combined to generate an accurate feature map of the object in frame i+1, which may be followed by a binary segmentation. This estimation-segmentation step may be repeated several times until Ci+1 converges.
In another set of embodiments, referred to as multi-frame-propagation model embodiments, segmentation information from one frame, e.g., an initial frame such as frame 1, may be used to determine segmentation for multiple subsequent frames. For example, various techniques may be used to robustly track the windows/classifiers as they are propagated through successive frames. An exemplary embodiment of such a multi-frame propagation model is illustrated in FIG. 6, where, as may be seen, a segmentation of frame 1 (or i), represented by the mask of frame 1 in the figure, may be used to propagate a segmentation contour from frame 1 to a subsequent frame 2 (or i+1), similar to the single-frame approach described above with respect to FIG. 4, possibly including an iterative process as indicated by the “iterate” denotations above frames 2 and 3, and as described above with reference to FIG. 5. As FIG. 6 indicates, in this embodiment, once the segmentation of frame 2 (i+1) is determined, this segmentation information may be used to determine the segmentation (contour) of the subsequent frame, e.g., frame 3 (i+2), and so on. Note, however, that in some embodiments, along with the segmentation information from the previous frame, information from the initial frame may also be used, e.g., a color map or other segmentation-related information, as will be discussed in more detail below.
FIG. 7—Flowchart of a Method for Performing Automatic Image Segmentation in a Video Sequence
FIG. 7 is a flowchart illustrating a method for automatically determining segmentation in a digital video sequence. The method shown in FIG. 7 may be used in conjunction with embodiments of the computer system shown in FIG. 1, among other devices. In various embodiments, some of the method elements shown may be performed concurrently, in a different order than shown, or may be omitted. Additional method elements may also be performed as desired. Any of the method elements described may be performed automatically (i.e., without user intervention). As shown, this method may operate as follows.
First, in 702, a segmentation shape prediction and a segmentation color model for a current image (e.g., a first image) of a video sequence may be determined based on existing segmentation information for at least one previous image of the video sequence. For example, in one embodiment, a user may manually segment the current image into a foreground and a background, storing the segmentation information for this current image, including a segmentation contour that divides the background from foreground, e.g., a foreground object, in the image.
The determination of the shaped prediction and color model may be performed via any of a variety of techniques, as desired. For example, regarding shape prediction, in one embodiment, scale invariant feature transform (SIFT) techniques may be employed to generate an estimate or rough version of the segmentation contour for the current image based on the at least one previous image of the sequence, i.e., based on the pre-existing segmentation contour. SIFT key points are reliable features for consecutive frames in videos. By matching the SIFT key points of the previous image/frame with corresponding key points in the current image/frame, one can determine a good initial guess of the contour in the current (or new) frame. Thus, more specifically, the method may search in the current frame for a best match for each (SIFT) key point inside the foreground object of the previous frame. From the point correspondence, an affine transform (e.g., specifying translation, rotation, shearing, and possibly scaling) may be determined that transforms {xj} to {yj} (j=1, 2, . . . n), e.g., in a least squares estimate sense.
FIG. 8 shows an example of matched key points (i.e., feature points) in consecutive video frames. As shown, each key point x in frame i corresponds to a key point in frame i+1. When determining these key points, in some embodiments, for efficiency and robustness, the search range may be limited to a region enclosing the contour, e.g., a rectangle slightly larger than the bounding box of the contour, as indicated by the dashed box surrounding the object bounded by the contour Ci. Moreover, in some embodiments, outliers may be omitted when fitting these points.
FIG. 9 illustrates such key points and their matches or correspondences in two consecutive frames of the exemplary video sequence introduced in FIG. 3 (and also used in FIGS. 4 and 6). Note that because the image changes between two consecutive frames are small, detecting and correlating the key points will generally be straightforward and quite reliable. Thus, the affine transform determined based on these points may provide ready means for generating a rough estimate of the initial contour, e.g., by propagating the contour via the transform to the next frame.
Thus, once the affine transform has been determined based on the matching key points in the two frames, the initial contour may be transformed to generate a rough estimate or predicted shape of the contour for the subsequent frame. As mentioned above, in some embodiments, a plurality of local classifiers may be constructed along the contour and used to perform operations with respect to the contour. For example, in some embodiments, a sliding window approach may be employed, where each classifier, whose center point lies on the contour, defines and operates on a local region around a respective contour point (the classifier's center), integrating color and shape information from the previous frame, e.g., a color model and a shape prediction, and determining the predicted contour accordingly. In one embodiment, the classifiers, represented in FIG. 4 as small rectangles along the segmentation contour of frames i and i+1, may be defined such that every point in the contour is covered by (e.g., contained by) at least two classifiers. Thus, each classifier box or window preferably overlaps at least two other classifiers. In other words, the respective region of each local classifier of the plurality of local classifiers overlaps the respective regions of at least two other local classifiers of the plurality of local classifiers
Thus, the shape alignment process may operate to roughly align the classifier windows with the foreground object in frame i+1.
Note that in prior art approaches, color models are generally constructed for the entire foreground object and the background, which may be of limited relevance to specific local regions of the foreground and background. As described above, in some embodiments, determining the segmentation shape prediction and the segmentation color model may include constructing a plurality of local classifiers for the at least one previous image, where each local classifier includes a respective region of the at least one previous image that contains a respective portion of a shape contour of the at least one previous image, and where the plurality of local classifiers cover the shape contour of the at least one previous image. Then, for each local classifier of the plurality of classifiers, a local segmentation shape prediction for the current image may be generated based on the respective portion of the shape contour of the at least one previous image contained in the local classifier.
More specifically, in some embodiments, generating a local segmentation shape prediction based on the respective portion of the shape contour may include generating an initial local segmentation shape prediction via scale invariant feature transform (SIFT) applied to a plurality of key points in the respective region, and generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour. In one embodiment, generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour may include determining a local average flow vector based on optical flow of foreground pixels in the respective region, and applying the local average flow vector to the points along the respective portion of the shape contour to generate the local segmentation shape prediction.
Finally, a local segmentation color model may be generated based at least on color information for the respective region of the at least one previous image included in the local classifier. Thus, the use of local classifiers to characterize and operate on local regions of the image may significantly enhance the accuracy and results of segmentation, particularly regarding images with complex foreground objects and/or backgrounds.
While applying the transform to each point on the contour (or some specified subset of such points, such as equally spaced sample points along the contour) will generate a rough estimate of the contour that approximately aligns the contour to the image of the subsequent frame, this transformation generally captures the object's principle rigid motion between the two frames, and thus may generally omit motion effects specific to local motion of parts of the object. To determine a better prediction of the contour, optical flow of contour pixels between the transformed frame and the next frame may be computed. However, due to the unreliability of optical flow on the boundary, e.g., where occlusion occurs, directly adding the flow vector to the contour points, i.e., at the pixel level, may produce erratic results. Thus, in on embodiment, rather than computing the optical flow based on the contour points themselves (using the center point per classifier), a local average flow inside the contour may be used. For example, turning now to FIG. 10, let x be a point on the transformed contour C*. Ω is the inside region of C*, and Nx is a local classifier or window centered at x. Now, point x is moved by the average flow vector v in region Ω∩Nx, i.e. x′=x+ v. In other words, the flow vector applied to x is the average of the flow vectors of all points that are in both the inner region Ω and the classifier window, i.e., that are in the intersection of these two point sets. This regional or local average optical flow is much more robust than that generated from single points, primarily due to the fact that the object's motion is generally locally smooth. By incorporating local averaged optical flow into the process, a more accurate and robust estimated contour may be generated.
Thus, from these two steps (transformation/alignment plus average optical flow), one may generate a prediction of the contour, or, more accurately, a plurality of predicted or estimated contour portions or segments, each covered by and associated with a respective classifier. This predicted or estimated contour may then be used as a shape prior (shape prediction) and may specify positions of the local classifiers. FIG. 11 illustrates a first frame (labeled frame 1) with user provided segmentation indicated by a white contour line around the foreground object, and a second frame (labeled frame 2) with the contour after alignment and optical flow. Note that the contour in frame 2, which corresponds to frame i+1 of FIG. 4, is very similar to the original contour (of frame 1), but is still not perfect, being an estimate or prediction. However, this contour, specifically, the contour segments composing the contour, may be used by the classifiers in determining an even better contour, as will now be described.
Building Local Classifiers
As noted above, in some embodiments, local classifiers may comprise a set of sliding windows along the contour. In one exemplary embodiment, the typical size of a classifier box or window may vary from 50×50 to 70×70 pixels in size, although any other sizes may be used as desired. In one embodiment, the centers of these windows may be equally spaced sample points along the contour Ci, as shown in FIG. 12 (note that for illustration only a few non-overlapping windows are shown). As also noted above, the number of windows may be set such that each point near the contour is covered by at least two windows. As described above, the centers of these overlapping windows may be transformed and (average optically) flowed into the next frame together with the contour. In other words, each of the classifiers, along with their respective contour segments or portions, may be propagated from frame 1 to frame 2 via shape alignment and local average optical flow, thus resulting in two sets of sliding windows or classifiers with one-to-one correspondence, denoted as {Wk i}, {Wk i+1}, k=1, 2, . . . N. In the below description, pairs of these two sets of classifiers may referred to as first and second classifiers for convenience. Said another way, a plurality of local classifiers for the current image corresponding to the plurality of local classifiers for the at least one previous image may be generated by applying the average flow vector to the plurality of local classifiers for the at least one previous image, wherein each local classifier for the current image comprises a respective region of the current image that contains a respective portion of a shape contour of the current image, and wherein the plurality of local classifiers of the current image cover the shape contour of the current image.
Per FIG. 12, given the labeled pixels in Wk i (first classifier), the pixels in Wk i+1 (second classifier) may be classified as foreground or background pixels based on their strong temporal correlation in color and shape. In other words, for each classifier, given the strong correlation between the shape and color of frame i and frame i+1, the classification of pixels of frame i (as foreground or background) may be used to classify those of frame i+1.
FIG. 13 illustrates color and shape integration with adaptive weights, according to one embodiment. In this exemplary embodiment, a color model and predicted shape (shape prior) for a particular local classifier are combined based on confidence levels pertaining to their respective background or foreground characterizations to generate a resultant feature map for the local region of the classifier. For example, as FIG. 13 indicates, based on a measure of the discriminativity of the color model for the classifier, denoted by σ, the contributions of the shape prior and the color model, denoted by Pc (foreground probability based on the color model) and Ps (foreground probability based on the shape prior) may be weighted and summed to generate an integrated probability (feature) map denoting foreground and background likelihoods for the pixels of the classifier. Said another way, the color and shape clues may be fused with adaptive weights depending on the discriminativity of the color model. The practical rule embodied in this process may be stated thusly: when colors are separable, trust colors; otherwise trust the shape. In other words, if the color model for the classifier makes a clear distinction between foreground colors and background colors, rely on the color model to classify the pixels of the region, and if the color model does not make a clear distinction, rely more on the shape prior to classify the pixels. In some embodiments, this approach may be considered to be a type of fuzzy logic pixel classification scheme, where color models and predicted shapes are used as appropriate to classify pixels as foreground or background pixels. More details regarding this process are provided below.
Determining the Color Model
One approach to calculating the foreground probabilities for the pixels in a propagated classifier Wk i+1 is via a Gaussian Mixture Model (GMM). In this approach, all the pixels in the local region or window of the second classifier are sampled except for a narrow band around the contour, which in some embodiments may be defined by (|dx|<Δ), where Δ is the width of an uncertainty band in the first classifier, and where dx is the maximum distance of a pixel x from the contour in the classifier. In other words, pixels near the estimated contour are more difficult to classify as foreground or background pixels because the estimated or predicted contour almost certainly has come error, and so pixels near the estimated contour on the FG side may actually be on the BG side of the actual (unknown) boundary, and vice versa.
FIG. 14 illustrates regions for correlated classifiers, e.g., first and second classifiers, Wk i and Wk i+1, where each region is divided into respective foreground and background sub-regions. More specifically, the first classifier is divided into a foreground F1 and a background B1, and the second classifier is divided into a foreground F2 and a background B2, as shown. The sampled pixels from the first classifier may be denoted by {F1; B1}. In some embodiments, to make a richer color model, colors in the second classifier may also be sampled. Note that because the predicted contour is not always accurate, the uncertainty band in the second classifier is wider than that of the first classifier, and thus the sampled pixels, denoted by {F2; B2}, are further from the contour, where their FG/BG status is more reliable. More specifically,
F 2 ={x|d x>max{d x}/2},
and
B 2 ={x|d x<min{d x}/2},
where dx is the signed distance transform from the contour, with foreground being the positive side. Note that the particular criteria for the sampled pixels and uncertainty bands presented herein are meant to be exemplary only, and that other values, constants, and relationships may be used as desired.
In the case of very large inter-frame motion, the tentative sampling in Wk i+1 may be inaccurate. For example, the pixels demarcated as {F2, B2} may both be on the foreground or the background side of the region, i.e., the contour prediction the pixels are segregated by may be so inaccurate that the actual contour is not even in the region, in which case the {F2, B2} pixels should not be used. Thus, criteria may be set or specified to determine whether or not to include {F2, B2} in the determination of the color model. Two candidate color models may be built:
Simple model: {F1, B1}
Mixture model: {F1, B1; F2, B2}.
Assuming the foreground does not considerably change (foreground bias), one may expect that adding {F2; B2} will reduce the misclassification in Wk i+1 (e.g., background pixels classified as foreground or vice versa). This can be verified simply by counting the number of pixels whose probabilities are larger than 0.5. for each model, and the model that results in a smaller number adopted for use.
In one embodiment, 6-components (e.g., 3 for foreground colors and 3 for background colors) may be used to train the GMM. The final foreground probabilities may be normalized via a log scale, i.e.:
P C ( x ) = log P B ( x ) log P F ( x ) + log P B ( x ) , x W k i + 1 .
FIG. 15 illustrates exemplary differences resulting from the use of the two candidate color models, e.g., the mixed color model, based on pixels from both classifiers {F1, B1; F2, B2}, and the simple color model, based only on pixels from the first classifiers {F1, B1}. In the upper row, the classifier regions of FIG. 14 are used, where as may be seen, the probability map generated by the mixed model is significantly less ambiguous than that generated by the simple model, i.e., the foreground and background are more clearly separated, and also correspond more closely to the second image. Thus, in this case, the mixed color model should be used. In the bottom row, the second frame doesn't have a foreground portion, but the predicted contour still indicates one. Note that the probability map using the mixed color model doesn't correspond with the second image (because the foreground changed so much), whereas the probability map using the simple color model correctly reflects the absence of foreground pixels, and so in this case, the simple color model should be used.
Summarizing the above, in some embodiments, generating a local segmentation color model may include generating a local segmentation simple color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image, and generating a local segmentation mixed color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image and color information for the respective region of the current image included in the local classifier for the current image. Discriminability of the local segmentation mixed color model and the local segmentation simple color model may be determined. Generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier may then include selecting the local segmentation simple color model as the local segmentation color model if the local segmentation simple color model has greater discriminability than the local segmentation mixed color model, and selecting the local segmentation mixed color model as the local segmentation color model if the local segmentation mixed color model has greater discriminability than the local segmentation simple color model.
Shape Prior
As discussed above, in addition to the color model, a shape prior, i.e., a predicted shape, may also be used to generate the probability or feature map for a classifier region. More specifically, the contribution from the predicted shape (as part of a weighted sum) may be based on the discriminability of the color model, where if the color model makes a clear distinction between foreground colors and background colors, the color model is relied on to classify the pixels of the region, and if the color model does not make a clear distinction, the shape prior is relied on to classify the pixels, with intermediate situations addressed by weights applied to each, e.g., where the weights sum to some normalized value, e.g., 1. In other words, in some embodiments, the weights are coefficients in a linear sum of the color and shape contributions. Note, however, that in other embodiments, the shape and color contributions may be determined by a non-linear combination.
FIG. 16 illustrates shape prediction confidence, according to one embodiment. More specifically, FIG. 16 illustrates an exemplary relationship between the confidence of pixel classifications based on the predicted contour and the contribution of the predicted shape probability map to the integrated probability map discussed above, e.g., in a weighted linear sum of the color and shape contributions. As FIG. 16 shows, in this embodiment, for each pixel, the weight applied the shape contribution, represented by the Ps axis, ranges from zero to 1, i.e., ranging from no contribution to being the only contribution, depending on the distance of the pixel from the estimated contour, represented by the d axis. As discussed above, the contributions from the color model and the predicted shape may be complementary, such that as one increases, the other decreases. Note that according to the plot of FIG. 16, a d value of 0 means that the pixel is (at least approximately) on the contour, and thus there may be maximum uncertainly as to which side (FG or BG) of the (actual) contour the pixel is on based on the predicted shape, and so the weight applied to the shape prediction will be zero. Moreover, the classification of pixels with positions sufficiently removed from 0 (in either direction), i.e., deep in the FG or BG portions of the region, may be reliably made via the predicted shape, giving a weight of 1. Expressed mathematically:
Let Mk be the binary (foreground) mask enclosed by Ci+1, i.e.:
M k ( x ) = { 1 , d x 0 0 , d x < 0.
A shape confidence term (weight) PS may be defined as:
P S ( x ) = { d x σ , d x σ 1 , d x > σ ,
where σ is the parameter controlling the blurry width of the shape, i.e., an uncertainty band with respect to the predicted shape, i.e., the estimated contour, where, as noted above, σ denotes the discriminability of the color model. In other words, the value of σ depends on the separation or discriminability of foreground and background in the color model, and this value is used to blur the contour of the predicted shape, such that the more reliable the color model is, the less clear the predicted shape is regarding the contour. Thus, as one considers pixels further from the estimated contour, the predicted shape is increasingly relied on to classify the pixels as FG or BG pixels, and conversely, for pixels increasingly near the estimated contour, the color map is increasingly relied upon, where the width and rate of the switchover is specified by σ, as FIG. 16 shows. Of course, it should be noted that other embodiments may integrate the color and shape contributions in different ways, as desired.
Color and Shape Integration
FIG. 17 illustrates shape prediction constraints based on discriminativity of the color model, according to one embodiment. As noted above with respect to FIG. 16, the blurry width c is related to the discriminativity of the color model. When foreground and background colors are separable, c is large and the shape constraint is loose, i.e., the blurred band in the predicted shape probability map is wider; when FG and BG colors are mixed, c becomes small and the shape constraint is tight, i.e., the blurred band in the predicted shape probability map is thinner.
In one embodiment, classification error may be used as the measure of color discriminativity. For example, let Lk be the predicted label (F=1, B=0) of Wk i from the color model. The classification error e is the sum of misclassifications, weighted by the distance to the contour:
e = W k i L k ( x ) - M k ( x ) · ω ( x ) x W k i ω ( x ) x , where ω ( x ) = exp ( - d x 2 2 σ d 2 ) .
As shown in FIG. 17, c is a decreasing function of e:
σ = { σ min + a ( e - e max ) r , 0 e e max σ min , e > e max , where a = σ max - σ min e max r .
Said another way, once the color map for frame i+1 is determined (as described above), it may be used to (re)classify the pixels of frame i (whose actual classifications are already known, since that image has already been segmented), and by determining the errors due to the color model, determine the confidence or reliability of the color model, i.e., to determine σ. In other words, once the error e is computed, σ may be computed therefrom. Note that per the expression above, bounds may be put on the values of σ, specifically, σmin and σmax
In one exemplary implementation, emax=0.12, σmax=l, σmin=2, and r=2. l is the size of Wk l, and, as mentioned above, the final probability is a weighted linear combination of color and shape priors:
P int(x)=P S(x)M k(x)+(1−P S(x))P C(x).
Thus, as indicated in FIG. 17, the minimum discriminability of the color model σmin may correlate with the maximum error with respect to the color model, and may define the point at which the shape prediction is the dominant contributor.
FIG. 18 illustrates color and shape integration, according to one embodiment. More specifically, FIG. 18 illustrates exemplary color and shape probability maps (i.e., feature maps), Pc and Ps, and a corresponding integrated probability map Pint for a classifier (region). Note that the integrated probability or feature map is a more accurate and precise estimate of the contour than either of the color or shape maps. Thus, by using embodiments of the above techniques, each classifier may determine a probability or feature map for a respective portion of the image proximate to the estimated contour.
Combined Feature Map
In one embodiment, the probabilities (i.e., probability or feature maps) in all local windows, i.e., from all local classifiers, may be combined to form a combined feature map. For example, for each local classifier of the plurality of classifiers, a local feature map estimation may be generated based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, where the local feature map estimation classifies pixels in the respective region as background or foreground pixels. Then, a feature map estimation for the current image may be generated by combining the local feature map estimations.
If a pixel is covered by multiple windows, its respective probability (classification) may be determined from a weighted linear combination of values in different windows, i.e., from different classifiers, e.g.,:
P ( x ) = k P int ( x - c k ) ω k k ω k ω k = ( x - c k + ɛ ) - 1 ,
where ck is the center of Wk i+1, k sums over all the windows that cover x, and ε is a small constant. In other words, for a pixel or point x, the weights applied to the corresponding probability values from each of the overlapping probability or feature maps from the classifiers in the linear sum may be based on the distance of x from the center point of each classifier window. Of course, this above combination scheme is but exemplary only, and is not intended to limit the techniques used to combine the local feature maps to any particular approach.
Thus, a combined probability or feature map for the image (e.g., of frame i+1) may be determined using both color models and shape predictions for each of a plurality of local classifiers. Said another way, a plurality of local feature maps, e.g., foreground masks, may be stitched together to form a global or combined feature map or mask.
In 704, a segmentation of the current image may be automatically generated based on a weighted combination of the segmentation shape prediction and the segmentation color model, as described below.
Segmentation
In one embodiment, the combined feature (probability) map may be used to segment the image (into foreground and background portions). For example, in one embodiment, the combined feature map (i.e., the generated feature map estimation for the current image) may be used to segment the image using an image processing algorithm such as Graph Cut, where the probability values may be set as data cost, after which a GAC (Geodesic Active Contour) algorithm may be performed to further regularize the boundary, e.g., implemented by level sets. Note, however, that any other algorithms and/or tools may be used as desired.
In an alternative embodiment, rather than generating a combined feature map, then segmenting the image according to the combined feature map, the local feature maps may each be used to perform a local segmentation for each classifier window, after which these local segmentations (segmented image portions) may be stitched together to form the segmented image.
Iterative Refinement
In some embodiments, portions of the above techniques may be repeated in an iterative manner to further refine the segmentation. For example, using the segmentation boundary as an initial contour, the feature map estimation and segmentation process described above may be repeated to produce a more accurate result. In one embodiment, during iterations, the windows or classifier regions may be fixed, i.e., only the contour inside (the local foreground portion of the classifier region) may be updated. For each iteration, different color samples may be selected, and the current contour may be used as the shape prior or predicted shape. Local results may then be combined for segmentation. The iterations may terminate when the local classifier's contour does not change any more, e.g., within some specified tolerance, e.g., up to a few (10-20) pixels. FIG. 19 illustrates contour iteration with respect to feature map estimation and segmentation, according to one embodiment. As may be seen, after the feature map estimation and segmentation, the original (estimated) contour, which passes through the center point of the classifier region, is moved to the right of the center. This contour may then be used for the next iteration, i.e., for the next feature map estimation and segmentation. Said another way, automatically generating a segmentation of the current image produces a shape contour for the current image, and the method may include iteratively performing the above-described determining the segmentation shape prediction and segmentation color model and automatically generating a segmentation of the current image, until the shape contour for the current image converges, where the segmentation of the current image for each iteration is used as the segmentation information for the next iteration.
Typically, different classifiers (windows) converge at different speeds. Thus, at the end of each iteration, the converged classifiers may be marked, and only the unmarked classifiers may be updated in future iterations. As noted above, the iterations may be performed until all classifiers converge, or until it is determined that convergence will not occur, in which case the user may intervene, e.g., by manually segmenting the image, as will be discussed below in more detail.
In 706, the segmentation of the current image may be stored, e.g., in a memory medium of the computer system 100, and/or a memory medium coupled to the computer system, e.g., over a network, e.g., a SAN. The method may then repeat the above-described method elements for subsequent images or frames of the video sequence, as described below in more detail. In other words, the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, the automatically generating a segmentation of the current image, and the storing of the segmentation of the current image, may be repeated for one or more contiguous images in the video sequence.
In one embodiment, storing the segmentation of the current image may include storing the information describing or specifying the segmentation of the image, e.g., for subsequent use in processing the image, e.g., for special effects, etc. In other embodiments, the segmented image itself may be stored.
Multi-Frame Propagation
A simple concatenation of the single-frame-propagation techniques described above may result in significant inaccuracies, since the error accumulates from frame to frame. Two approaches to effectively control or ameliorate the error divergence are described below. The first approach is to constantly rely on the color samples in the first frame. Thus, while the single-frame propagation approach forms the fundamental basis of the automatic segmentation techniques disclosed herein, in some embodiments, this approach may be extended and modified to form a multi-frame propagation process where color information for an initial frame is used to automatically perform segmentation for multiple subsequent frames.
FIG. 20 illustrates multi-frame propagation of segmentation using a color model of an initial frame, according to one embodiment. As FIG. 20 indicates, a first frame C1 is used to generate a sequence of subsequent contours or segmentations, specifically, for subsequent frames C2-Cn. As may be seen, the color model for the initial frame (C1) is used for each of the subsequent frames, while shape information, e.g., a shape prediction, for each frame is used for the next frame. In other words, the automatic segmentation of each frame uses the color model from the initial frame (and possibly the current frame in the “mixed model” case), but uses the predicted shape of the immediately previous frame. In other words, for determining segmentation for a frame Ci+1, instead of building a color model from Ci and Ci+1, the color model is determined from C1 (and possibly Ci+1). This scheme keeps the segmentation error at a constant level for every frame, as opposed to the simple concatenation approach where the error diverges or increases with the propagation. Note that for each subsequent frame the automatic segmentation is an iterative process, similar to the iterative refinement described above.
Said in a slightly different way, in some embodiments, for each iteration of the above iteratively performing (of the determining the segmentation shape prediction and segmentation color model and automatically generating a segmentation of the current image), upon convergence of the shape contour, the local classifier may be repositioned onto the shape contour. This repositioning may include determining a normal distance from the local classifier's center to the shape contour, and moving the local classifier onto the shape contour based at least in part on the normal distance. The determining a normal distance and the moving the local classifier may ameliorate propagation and divergence of errors. In one embodiment, local averages of the normal distance may be used to reposition each window.
In a second approach to error confinement, a feedback correction may be added to classifier window positions, which may enable the classifiers to keep robust track of the contour or boundary. FIG. 21 illustrates multi-frame propagation of segmentation using a feedback correction approach with respect to window/classifier positions, according to one embodiment. More specifically, FIG. 21 illustrates an exemplary embodiment of such a process, where, as may be seen, initial window positions are indicated in element (a) where the contour passes through the center points of multiple classifier windows. This may represent the situation resulting from the rough alignment of the classifiers (and respective contour segments) via shape prediction. In element (b), a new boundary or contour is formed upon convergence of the iterative refinement process. Then, for each window center, its displacement to the nearest point on the new contour or boundary may be determined. In other words, once the new contour is determined, the normal displacement (vector) from each classifier center point to the new contour may be determined. Then, as indicated in element (c), the classifier window centers may be moved based on the displacement. For example, in one embodiment, the classifier window centers may be moved according to an average displacement around the region, e.g., based on an average of the displacement vectors of neighboring or nearby classifiers, e.g., those that overlap the current classifier, e.g., vectors for windows i−2, i−1, i, i+1, and i+1 may be averaged to move window I, or vectors for classifiers within some distance of the current window may be averaged, etc., as desired. In an alternative embodiment, the classifier window centers may simply be moved to the contour based on their respective displacements. Finally, as illustrated in element (d) of FIG. 21, the boundary or contour and the classifier window centers may be moved or propagated to the next frame via shape prediction, as described above. Thus, once the contour or boundary is moved, the windows centers may subsequently be moved to (or near) the contour.
Thus, one or both of the above approaches to error confinement may be used to limit or ameliorate the propagation and divergence of errors in the automatic segmentation process, although it should be noted that any other error management techniques may be used as desired.
User Interaction
As noted above with reference to FIG. 2 and elsewhere, in some embodiments, in some embodiments, a graphical user interface (GUI) may be provided that allows the user to modify segmentation results, e.g., whereby the user may interact with and intervene in the automatic segmentation process. For example, in situations where an automatically determined contour/segmentation fails to converge, or where the contours are determined to be inaccurate, the user may edit the segmentation results, e.g., in a forward progressive fashion.
Given a well segmented frame, the method may automatically propagate the segmentation to the next N frames, and the user may play the video forward to check the results until an error is found. Two modes of user correction are now presented.
Local Correction
For minor mistakes, the user may correct only a small part of the contour. In other words, only a limited number of windows may be manually updated. The correction may then propagate to the future frames.
Reset Starting Frame
In cases where more significant corrections are required, e.g., in number and/or kind, e.g., in cases where, for example, the contour is drifting away from boundary, the foreground object is moving out/into the scene, foreground occlusion, etc., the user may manually correct the current frame, and the current frame may be set as the first or initial frame for the automatic segmentation process, and the method proceeds from this frame, propagating forward until another error occurs. The entire video sequence is segmented when the last frame is reached. FIG. 22 illustrates user interaction to correct or reset multi-frame propagation of segmentation in a video sequence, according to one embodiment, where the top sequence of frames (1 through 5) are automatically segmented based on initial frame 1, but where an error is detected in frame 3 and corrected by the user. Then, as FIG. 22 indicates, corrected frame 3 is reset or designated as an initial frame for continued (recomputed) segmentation of successive frames (4 through 7).
Described in more detail, in some embodiments, performing the above-described determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, automatically generating a segmentation of the current image, and storing the segmentation of the current image, for one or more contiguous images in the video sequence may include performing the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, automatically generating a segmentation of the current image, and storing the segmentation of the current image, for a first plurality of contiguous images in the video sequence, including an ultimate (i.e., last) image in the first plurality of contiguous images, then editing segmentation of the ultimate image in response to input, thereby generating edited segmentation information, then performing the determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, automatically generating a segmentation of the current image, and storing the segmentation of the current image, for a second plurality of contiguous images in the video sequence, including a first image in the second plurality of contiguous images which is contiguous with the ultimate image in the first plurality of contiguous images in the video sequence. The existing segmentation information used in the determining a segmentation shape prediction and a segmentation color model for the first image in the second plurality of contiguous images may thus include the edited segmentation information.
It should be noted that while the above techniques have been describe as a forward propagation of segmentation in a video sequence, in some embodiments, the techniques may also or instead be propagated in the reverse direction. In other words, the techniques described herein are agnostic or generic with respect to the particular direction of the video sequence.
In some embodiments, this aspect may be used to possibly improve the segmentation process. For example, in one embodiment, embodiments of the methods described above may be performed on a video sequence (possibly a small sub-sequence within the larger video sequence) from either end, e.g., concurrently and/or sequentially, e.g., until the contours for each image converge. For example, in one embodiment, the user may manually segment two key frames bounding a sequence, then propagate inward from both ends, possibly stopping in the middle (at least temporarily) to reconcile competing contours for that image, then optionally continuing to opposite ends, refining the previously computed segmentation (by the opposite propagation). Other variations of this bi-directional technique are also contemplated.
Thus, various embodiments of the above techniques may be used to automatically propagate foreground/background image segmentation in a video sequence.
Exemplary Results
FIGS. 23 and 24 illustrate exemplary video sequences resulting from application of embodiments of the above techniques, where original images of a video sequence are presented vertically on the left (top to bottom), corresponding segmentation masks or feature maps are presented in the middle of the figures, and corresponding images with segmented foreground composited on blue backgrounds are presented vertically on the right. As may be seen, in both sequences, the first (top) segmentation mask is provided by the user. Note that in the sequence of FIG. 23, every 10th frame is shown, as indicated by the frame numbers labeling each original frame image.
Thus, various embodiments of the systems and methods disclosed herein may be used to automatically perform image segmentation in a digital video image sequence.
Although the embodiments above have been described in detail, numerous variations and modifications will become apparent to those skilled in the art once the above disclosure is fully appreciated. It is intended that the following claims be interpreted to embrace all such variations and modifications.

Claims (46)

1. A non-transitory computer-readable storage medium storing program instructions computer-executable to perform:
determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence based on existing segmentation information for at least one previous image of the video sequence;
automatically generating a segmentation of the current image based on a weighted combination of the segmentation shape prediction and the segmentation color model; and
storing the segmentation of the current image.
2. The non-transitory computer-readable storage medium of claim 1, wherein said determining the segmentation shape prediction and the segmentation color model comprises:
constructing a plurality of local classifiers for the at least one previous image, wherein each local classifier comprises a respective region of the at least one previous image that contains a respective portion of a shape contour of the at least one previous image, and wherein the plurality of local classifiers cover the shape contour of the at least one previous image; and
for each local classifier of the plurality of classifiers:
generating a local segmentation shape prediction for the current image based on the respective portion of the shape contour of the at least one previous image contained in the local classifier; and
generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier.
3. The non-transitory computer-readable storage medium of claim 2, wherein said automatically generating the segmentation of the current image comprises:
for each local classifier of the plurality of classifiers:
generating a local feature map estimation based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, wherein the local feature map estimation classifies pixels in the respective region as background or foreground pixels;
generating a feature map estimation for the current image by combining the local feature map estimations; and
generating the segmentation of the current image based on the generated feature map.
4. The non-transitory computer-readable storage medium of claim 3, wherein said generating a local segmentation shape prediction based on the respective portion of the shape contour comprises:
generating an initial local segmentation shape prediction via scale invariant feature transform (SIFT) applied to a plurality of key points in the respective region; and
generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour.
5. The non-transitory computer-readable storage medium of claim 4, wherein said generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour comprises:
determining a local average flow vector based on optical flow of foreground pixels in the respective region;
applying the local average flow vector to the points along the respective portion of the shape contour to generate the local segmentation shape prediction.
6. The non-transitory computer-readable storage medium of claim 5, wherein the program instructions are further computer-executable to perform:
constructing a plurality of local classifiers for the current image corresponding to the plurality of local classifiers for the at least one previous image by applying the average flow vector to the plurality of local classifiers for the at least one previous image, wherein each local classifier for the current image comprises a respective region of the current image that contains a respective portion of a shape contour of the current image, and wherein the plurality of local classifiers of the current image cover the shape contour of the current image.
7. The non-transitory computer-readable storage medium of claim 6, wherein said generating a local segmentation color model comprises:
generating a local segmentation simple color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image;
generating a local segmentation mixed color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image and color information for the respective region of the current image included in the local classifier for the current image;
determining discriminability of the local segmentation mixed color model and the local segmentation simple color model;
wherein said generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier comprises:
if the local segmentation simple color model has greater discriminability than the local segmentation mixed color model, selecting the local segmentation simple color model as the local segmentation color model; and
if the local segmentation mixed color model has greater discriminability than the local segmentation simple color model, selecting the local segmentation mixed color model as the local segmentation color model.
8. The non-transitory computer-readable storage medium of claim 7, wherein said generating a local feature map estimation based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier comprises:
for each pixel of at least a subset of pixels in the respective region:
determining a shape confidence measure based on distance of the pixel from the portion of the shape contour and the discriminability of the local segmentation color model;
determining a color confidence measure based on ability of the local segmentation color model to classify foreground and background pixels in the respective region of the at least one previous image;
classifying the pixel as background or foreground using the local segmentation shape weighted by the shape confidence measure and the local segmentation color model weighted by the color confidence measure.
9. The non-transitory computer-readable storage medium of claim 2, wherein said automatically generating a segmentation of the current image produces a shape contour for the current image, wherein the program instructions are further executable to perform:
iteratively performing said determining the segmentation shape prediction and segmentation color model and said automatically generating a segmentation of the current image, until the shape contour for the current image converges, wherein the segmentation of the current image for each iteration is used as the segmentation information for the next iteration.
10. The non-transitory computer-readable storage medium of claim 9, wherein the program instructions are further computer-executable to perform:
for each iteration of said iteratively performing, upon convergence of the shape contour, repositioning the local classifier onto the shape contour, comprising:
determining a normal distance from the local classifier's center to the shape contour; and
moving the local classifier onto the shape contour based at least in part on the normal distance;
wherein said determining a normal distance and said moving the local classifier ameliorates propagation and divergence of errors.
11. The non-transitory computer-readable storage medium of claim 2, wherein the respective region of each local classifier of the plurality of local classifiers overlaps the respective regions of at least two other local classifiers of the plurality of local classifiers.
12. The non-transitory computer-readable storage medium of claim 1, wherein the program instructions are further computer-executable to perform:
performing said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for one or more contiguous images in the video sequence.
13. The non-transitory computer-readable storage medium of claim 12, wherein for the one or more contiguous images in the video sequence, said determining the segmentation color model comprises selecting the segmentation color model of the at least one previous image, wherein utilization of the segmentation color model of the at least one previous image ameliorates propagation and divergence of errors.
14. The non-transitory computer-readable storage medium of claim 12, wherein said performing comprises:
performing said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for a first plurality of contiguous images in the video sequence, including an ultimate image in the first plurality of contiguous images;
editing segmentation of the ultimate image in response to input, thereby generating edited segmentation information; and
performing said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for a second plurality of contiguous images in the video sequence, including a first image in the second plurality of contiguous images which is contiguous with the ultimate image in the first plurality of contiguous images in the video sequence, wherein the existing segmentation information used in said determining a segmentation shape prediction and a segmentation color model for the first image in the second plurality of contiguous images comprises the edited segmentation information.
15. The non-transitory computer-readable storage medium of claim 1, wherein the existing segmentation information indicates a segmentation contour of the at least one previous image of the video sequence, wherein the segmentation contour divides background from foreground in the at least one previous image.
16. A computer-implemented method, comprising:
performing, by one or more computer processors;
determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence based on existing segmentation information for at least one previous image of the video sequence;
automatically generating a segmentation of the current image based on a weighted combination of the segmentation shape prediction and the segmentation color model; and
storing the segmentation of the current image.
17. The computer-implemented method of claim 16, wherein said determining the segmentation shape prediction and the segmentation color model comprises:
constructing a plurality of local classifiers for the at least one previous image, wherein each local classifier comprises a respective region of the at least one previous image that contains a respective portion of a shape contour of the at least one previous image, and wherein the plurality of local classifiers cover the shape contour of the at least one previous image; and
for each local classifier of the plurality of classifiers:
generating a local segmentation shape prediction for the current image based on the respective portion of the shape contour of the at least one previous image contained in the local classifier; and
generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier.
18. The computer-implemented method of claim 17, wherein said automatically generating the segmentation of the current image comprises:
for each local classifier of the plurality of classifiers:
generating a local feature map estimation based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, wherein the local feature map estimation classifies pixels in the respective region as background or foreground pixels;
generating a feature map estimation for the current image by combining the local feature map estimations; and
generating the segmentation of the current image based on the generated feature map.
19. The computer-implemented method of claim 18, wherein said generating a local segmentation shape prediction based on the respective portion of the shape contour comprises:
generating an initial local segmentation shape prediction via scale invariant feature transform (SIFT) applied to a plurality of key points in the respective region; and
generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour.
20. The computer-implemented method of claim 19, wherein said generating the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour comprises:
determining a local average flow vector based on optical flow of foreground pixels in the respective region;
applying the local average flow vector to the points along the respective portion of the shape contour to generate the local segmentation shape prediction.
21. The computer-implemented method of claim 20, further comprising:
constructing a plurality of local classifiers for the current image corresponding to the plurality of local classifiers for the at least one previous image by applying the average flow vector to the plurality of local classifiers for the at least one previous image, wherein each local classifier for the current image comprises a respective region of the current image that contains a respective portion of a shape contour of the current image, and wherein the plurality of local classifiers of the current image cover the shape contour of the current image.
22. The computer-implemented method of claim 21, wherein said generating a local segmentation color model comprises:
generating a local segmentation simple color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image;
generating a local segmentation mixed color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image and color information for the respective region of the current image included in the local classifier for the current image;
determining discriminability of the local segmentation mixed color model and the local segmentation simple color model;
wherein said generating a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier comprises:
if the local segmentation simple color model has greater discriminability than the local segmentation mixed color model, selecting the local segmentation simple color model as the local segmentation color model; and
if the local segmentation mixed color model has greater discriminability than the local segmentation simple color model, selecting the local segmentation mixed color model as the local segmentation color model.
23. The computer-implemented method of claim 22, wherein said generating a local feature map estimation based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier comprises:
for each pixel of at least a subset of pixels in the respective region:
determining a shape confidence measure based on distance of the pixel from the portion of the shape contour and the discriminability of the local segmentation color model;
determining a color confidence measure based on ability of the local segmentation color model to classify foreground and background pixels in the respective region of the at least one previous image;
classifying the pixel as background or foreground using the local segmentation shape weighted by the shape confidence measure and the local segmentation color model weighted by the color confidence measure.
24. The computer-implemented method of claim 17, wherein said automatically generating a segmentation of the current image produces a shape contour for the current image, wherein the program instructions are further executable to perform:
iteratively performing said determining the segmentation shape prediction and segmentation color model and said automatically generating a segmentation of the current image, until the shape contour for the current image converges, wherein the segmentation of the current image for each iteration is used as the segmentation information for the next iteration.
25. The computer-implemented method of claim 24, further comprising:
for each iteration of said iteratively performing, upon convergence of the shape contour, repositioning the local classifier onto the shape contour, comprising:
determining a normal distance from the local classifier's center to the shape contour; and
moving the local classifier onto the shape contour based at least in part on the normal distance;
wherein said determining a normal distance and said moving the local classifier ameliorates propagation and divergence of errors.
26. The computer-implemented method of claim 17, wherein the respective region of each local classifier of the plurality of local classifiers overlaps the respective regions of at least two other local classifiers of the plurality of local classifiers.
27. The computer-implemented method of claim 16, further comprising:
performing said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for one or more contiguous images in the video sequence.
28. The computer-implemented method of claim 27, wherein for the one or more contiguous images in the video sequence, said determining the segmentation color model comprises selecting the segmentation color model of the at least one previous image, wherein utilization of the segmentation color model of the at least one previous image ameliorates propagation and divergence of errors.
29. The computer-implemented method of claim 27, wherein said performing comprises:
performing said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for a first plurality of contiguous images in the video sequence, including an ultimate image in the first plurality of contiguous images;
editing segmentation of the ultimate image in response to input, thereby generating edited segmentation information; and
performing said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for a second plurality of contiguous images in the video sequence, including a first image in the second plurality of contiguous images which is contiguous with the ultimate image in the first plurality of contiguous images in the video sequence, wherein the existing segmentation information used in said determining a segmentation shape prediction and a segmentation color model for the first image in the second plurality of contiguous images comprises the edited segmentation information.
30. The computer-implemented method of claim 16, wherein the existing segmentation information indicates a segmentation contour of the at least one previous image of the video sequence, wherein the segmentation contour divides background from foreground in the at least one previous image.
31. A system, comprising:
at least one processor; and
a memory coupled to the at least one processor, wherein the memory stores program instructions, wherein the program instructions are executable by the at least one processor to:
determine a segmentation shape prediction and a segmentation color model for a current image of a video sequence based on existing segmentation information for at least one previous image of the video sequence;
automatically generate a segmentation of the current image based on a weighted combination of the segmentation shape prediction and the segmentation color model; and
store the segmentation of the current image.
32. The system of claim 31, wherein to determine the segmentation shape prediction and the segmentation color model, the program instructions are executable to:
construct a plurality of local classifiers for the at least one previous image, wherein each local classifier comprises a respective region of the at least one previous image that contains a respective portion of a shape contour of the at least one previous image, and wherein the plurality of local classifiers cover the shape contour of the at least one previous image; and
for each local classifier of the plurality of classifiers:
generate a local segmentation shape prediction for the current image based on the respective portion of the shape contour of the at least one previous image contained in the local classifier; and
generate a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier.
33. The system of claim 32, wherein to automatically generate the segmentation of the current image, the program instructions are executable to:
for each local classifier of the plurality of classifiers:
generate a local feature map estimation based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, wherein the local feature map estimation classifies pixels in the respective region as background or foreground pixels;
generate a feature map estimation for the current image by combining the local feature map estimations; and
generate the segmentation of the current image based on the generated feature map.
34. The system of claim 33, wherein to generate a local segmentation shape prediction based on the respective portion of the shape contour, the program instructions are executable to:
generate an initial local segmentation shape prediction via scale invariant feature transform (SIFT) applied to a plurality of key points in the respective region; and
generate the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour.
35. The system of claim 34, wherein to generate the local segmentation shape prediction by refining the estimate of the initial local segmentation shape prediction using optical flow applied to points along the respective portion of the shape contour, the program instructions are executable to:
determine a local average flow vector based on optical flow of foreground pixels in the respective region;
apply the local average flow vector to the points along the respective portion of the shape contour to generate the local segmentation shape prediction.
36. The system of claim 35, wherein the program instructions are further computer-executable to:
construct a plurality of local classifiers for the current image corresponding to the plurality of local classifiers for the at least one previous image by applying the average flow vector to the plurality of local classifiers for the at least one previous image, wherein each local classifier for the current image comprises a respective region of the current image that contains a respective portion of a shape contour of the current image, and wherein the plurality of local classifiers of the current image cover the shape contour of the current image.
37. The system of claim 36, wherein to generate a local segmentation color model, the program instructions are executable to:
generate a local segmentation simple color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image;
generate a local segmentation mixed color model based on color information for the respective region of the at least one previous image included in the local classifier for the at least one previous image and color information for the respective region of the current image included in the local classifier for the current image;
determine discriminability of the local segmentation mixed color model and the local segmentation simple color model;
wherein to generate a local segmentation color model based at least on color information for the respective region of the at least one previous image included in the local classifier, the program instructions are executable to:
if the local segmentation simple color model has greater discriminability than the local segmentation mixed color model, select the local segmentation simple color model as the local segmentation color model; and
if the local segmentation mixed color model has greater discriminability than the local segmentation simple color model, select the local segmentation mixed color model as the local segmentation color model.
38. The system of claim 37, wherein to generate a local feature map estimation based on a weighted combination of the local segmentation shape and the local segmentation color model for the local classifier, the program instructions are executable to:
for each pixel of at least a subset of pixels in the respective region:
determine a shape confidence measure based on distance of the pixel from the portion of the shape contour and the discriminability of the local segmentation color model;
determine a color confidence measure based on ability of the local segmentation color model to classify foreground and background pixels in the respective region of the at least one previous image;
classify the pixel as background or foreground using the local segmentation shape weighted by the shape confidence measure and the local segmentation color model weighted by the color confidence measure.
39. The system of claim 32, wherein said automatically generating a segmentation of the current image produces a shape contour for the current image, and wherein the program instructions are further executable to:
iteratively perform said determining the segmentation shape prediction and segmentation color model and said automatically generating a segmentation of the current image, until the shape contour for the current image converges, wherein the segmentation of the current image for each iteration is used as the segmentation information for the next iteration.
40. The system of claim 39, wherein the program instructions are further computer-executable to:
for each iteration of said iteratively performing, upon convergence of the shape contour, reposition the local classifier onto the shape contour, comprising:
determine a normal distance from the local classifier's center to the shape contour; and
move the local classifier onto the shape contour based at least in part on the normal distance;
wherein said determining a normal distance and said moving the local classifier ameliorates propagation and divergence of errors.
41. The system of claim 32, wherein the respective region of each local classifier of the plurality of local classifiers overlaps the respective regions of at least two other local classifiers of the plurality of local classifiers.
42. The system of claim 31, wherein the program instructions are further computer-executable to:
perform said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for one or more contiguous images in the video sequence.
43. The system of claim 42, wherein for the one or more contiguous images in the video sequence, to determine the segmentation color model, the program instructions are executable to select the segmentation color model of the at least one previous image, wherein utilization of the segmentation color model of the at least one previous image ameliorates propagation and divergence of errors.
44. The system of claim 42, wherein to perform said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for one or more contiguous images in the video sequence, the program instructions are executable to:
perform said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for a first plurality of contiguous images in the video sequence, including an ultimate image in the first plurality of contiguous images;
edit segmentation of the ultimate image in response to input, thereby generating edited segmentation information; and
perform said determining a segmentation shape prediction and a segmentation color model for a current image of a video sequence, said automatically generating a segmentation of the current image, and said storing the segmentation of the current image, for a second plurality of contiguous images in the video sequence, including a first image in the second plurality of contiguous images which is contiguous with the ultimate image in the first plurality of contiguous images in the video sequence, wherein the existing segmentation information used in said determining a segmentation shape prediction and a segmentation color model for the first image in the second plurality of contiguous images comprises the edited segmentation information.
45. The system of claim 31, wherein the existing segmentation information indicates a segmentation contour of the at least one previous image of the video sequence, wherein the segmentation contour divides background from foreground in the at least one previous image.
46. A computer-implemented method, comprising:
executing instructions on an electronic computing device so that binary digital electronic signals representing a segmentation shape prediction and a segmentation color model for a current image of a video sequence are determined based on existing segmentation information for at least one previous image of the video sequence;
executing instructions on the electronic computing device so that binary digital electronic signals representing a segmentation of the current image are automatically generated based on a weighted combination of the segmentation shape prediction and the segmentation color model; and
storing the segmentation of the current image in a memory location of the electronic computing device.
US12/275,096 2008-08-22 2008-11-20 Automatic video image segmentation Active 2031-01-06 US8175379B2 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
US12/275,096 US8175379B2 (en) 2008-08-22 2008-11-20 Automatic video image segmentation
CN2009102057713A CN101676953B (en) 2008-08-22 2009-08-24 Automatic video image segmentation
US13/448,162 US8422775B2 (en) 2008-08-22 2012-04-16 Automatic video image segmentation

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US9124208P 2008-08-22 2008-08-22
US12/275,096 US8175379B2 (en) 2008-08-22 2008-11-20 Automatic video image segmentation

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US13/448,162 Continuation US8422775B2 (en) 2008-08-22 2012-04-16 Automatic video image segmentation

Publications (2)

Publication Number Publication Date
US20100046830A1 US20100046830A1 (en) 2010-02-25
US8175379B2 true US8175379B2 (en) 2012-05-08

Family

ID=41696454

Family Applications (2)

Application Number Title Priority Date Filing Date
US12/275,096 Active 2031-01-06 US8175379B2 (en) 2008-08-22 2008-11-20 Automatic video image segmentation
US13/448,162 Active US8422775B2 (en) 2008-08-22 2012-04-16 Automatic video image segmentation

Family Applications After (1)

Application Number Title Priority Date Filing Date
US13/448,162 Active US8422775B2 (en) 2008-08-22 2012-04-16 Automatic video image segmentation

Country Status (2)

Country Link
US (2) US8175379B2 (en)
CN (1) CN101676953B (en)

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8358691B1 (en) * 2009-10-30 2013-01-22 Adobe Systems Incorporated Methods and apparatus for chatter reduction in video object segmentation using a variable bandwidth search region
US20130223732A1 (en) * 2012-02-28 2013-08-29 Brother Kogyo Kabushiki Kaisha Image processor capable of classifying original as color original quickly
US20130251260A1 (en) * 2010-12-08 2013-09-26 Alcatel Lucent Method and system for segmenting an image
US9342754B2 (en) * 2014-04-08 2016-05-17 Nokia Technologies Oy Image segmentation using blur and color
US9485433B2 (en) 2013-12-31 2016-11-01 Personify, Inc. Systems and methods for iterative adjustment of video-capture settings based on identified persona
US9563962B2 (en) 2015-05-19 2017-02-07 Personify, Inc. Methods and systems for assigning pixels distance-cost values using a flood fill technique
US9628722B2 (en) 2010-03-30 2017-04-18 Personify, Inc. Systems and methods for embedding a foreground video into a background feed based on a control input
US9740916B2 (en) 2013-12-31 2017-08-22 Personify Inc. Systems and methods for persona identification using combined probability maps
US9792676B2 (en) 2010-08-30 2017-10-17 The Board Of Trustees Of The University Of Illinois System for background subtraction with 3D camera
US9881207B1 (en) 2016-10-25 2018-01-30 Personify, Inc. Methods and systems for real-time user extraction using deep learning networks
US9883155B2 (en) 2016-06-14 2018-01-30 Personify, Inc. Methods and systems for combining foreground video and background video using chromatic matching
US10757346B1 (en) 2017-04-28 2020-08-25 Flixbay Technologies, Inc. Systems and methods for video extraction and insertion
US11659133B2 (en) 2021-02-24 2023-05-23 Logitech Europe S.A. Image generating system with background replacement or modification capabilities
US11800056B2 (en) 2021-02-11 2023-10-24 Logitech Europe S.A. Smart webcam system
WO2024026366A1 (en) * 2022-07-27 2024-02-01 Stryker Corporation Systems and methods for real-time processing of medical imaging data utilizing an external processing device

Families Citing this family (81)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2009032922A1 (en) 2007-09-04 2009-03-12 Objectvideo, Inc. Stationary target detection by exploiting changes in background model
JP5041229B2 (en) * 2007-12-07 2012-10-03 ソニー株式会社 Learning device and method, recognition device and method, and program
US8175379B2 (en) 2008-08-22 2012-05-08 Adobe Systems Incorporated Automatic video image segmentation
US9202137B2 (en) 2008-11-13 2015-12-01 Google Inc. Foreground object detection from multiple images
US20100158379A1 (en) * 2008-12-18 2010-06-24 Microsoft Corporation Image background removal
US8391594B1 (en) * 2009-05-28 2013-03-05 Adobe Systems Incorporated Method and apparatus for generating variable-width border masks
JP5290915B2 (en) * 2009-09-03 2013-09-18 キヤノン株式会社 Image processing apparatus, image processing method, and program
US8781253B2 (en) * 2010-01-22 2014-07-15 Thomson Licensing Method and apparatus for video object segmentation
CN102870135B (en) * 2010-06-29 2016-02-03 富士胶片株式会社 For the method and apparatus of shape extracting, dimension measuring device and distance-measuring device
CN101951511B (en) * 2010-08-19 2012-11-28 深圳市亮信科技有限公司 Method for layering video scenes by analyzing depth
CN101964911B (en) * 2010-10-09 2012-10-17 浙江大学 Ground power unit (GPU)-based video layering method
US8983179B1 (en) 2010-11-10 2015-03-17 Google Inc. System and method for performing supervised object segmentation on images
CN102004916B (en) * 2010-11-15 2013-04-24 无锡中星微电子有限公司 Image characteristic extraction system and method
US8682063B2 (en) 2010-11-24 2014-03-25 Adobe Systems Incorporated Methods and apparatus for dynamic color flow modeling
CN103035014A (en) * 2011-09-29 2013-04-10 索尼公司 Image processing device and image processing method and imaging device and imaging method
US9305357B2 (en) 2011-11-07 2016-04-05 General Electric Company Automatic surveillance video matting using a shape prior
CN102572205B (en) * 2011-12-27 2014-04-30 方正国际软件有限公司 Image processing method, device and system
US9202281B2 (en) * 2012-03-17 2015-12-01 Sony Corporation Integrated interactive segmentation with spatial constraint for digital image analysis
CN102737245B (en) * 2012-06-06 2014-06-11 清华大学 Three-dimensional scene object boundary detection method and device
US8792718B2 (en) 2012-06-29 2014-07-29 Adobe Systems Incorporated Temporal matte filter for video matting
US8897562B2 (en) * 2012-06-29 2014-11-25 Adobe Systems Incorporated Adaptive trimap propagation for video matting
CN103578094B (en) * 2012-07-20 2016-07-13 清华大学 Shot segmentation method
MY181564A (en) 2012-09-05 2020-12-29 Element Inc System and method for biometric authentication in connection with camera-equipped devices
CN102999921B (en) * 2012-11-09 2015-01-21 山东大学 Pixel label propagation method based on directional tracing windows
US8971575B2 (en) * 2012-11-23 2015-03-03 Cyberlink Corp. Systems and methods for tracking objects
CN103139663B (en) * 2013-01-25 2016-05-11 深圳先进技术研究院 The automatic detachment device of video and the method automatically splitting thereof
CN103198470B (en) * 2013-02-26 2017-02-15 清华大学 Image cutting method and image cutting system
KR20160016812A (en) * 2013-05-28 2016-02-15 톰슨 라이센싱 Image edits propagation to underlying video sequence via dense motion fields
EP2821997A1 (en) 2013-07-04 2015-01-07 Thomson Licensing Method and device for editing a video sequence
CN103366364B (en) * 2013-06-07 2016-06-29 太仓中科信息技术研究院 A kind of stingy drawing method based on color distortion
US9235781B2 (en) * 2013-08-09 2016-01-12 Kabushiki Kaisha Toshiba Method of, and apparatus for, landmark location
CN104424651A (en) * 2013-08-26 2015-03-18 株式会社理光 Method and system for tracking object
CN112950747A (en) * 2013-09-13 2021-06-11 斯特拉克斯私人有限公司 Method and system for assigning color to image, computer readable storage medium
JP5741660B2 (en) * 2013-09-18 2015-07-01 カシオ計算機株式会社 Image processing apparatus, image processing method, and program
US10096114B1 (en) * 2013-11-27 2018-10-09 Google Llc Determining multiple camera positions from multiple videos
CN106104635B (en) * 2013-12-06 2019-01-04 惠普发展公司,有限责任合伙企业 Block augmented reality object
GB2523330A (en) 2014-02-20 2015-08-26 Nokia Technologies Oy Method, apparatus and computer program product for segmentation of objects in media content
CN111628870B (en) * 2014-05-13 2022-03-18 埃利蒙特公司 System and method for electronic key provisioning, user authentication and access management
CN105094657A (en) * 2014-05-16 2015-11-25 上海京知信息科技有限公司 Multitouch-based interactive video object segmentation fusion method
JP6415607B2 (en) 2014-06-03 2018-10-31 エレメント,インク. Exit and authentication related to mobile devices
US9424484B2 (en) 2014-07-18 2016-08-23 Adobe Systems Incorporated Feature interpolation
US9471828B2 (en) 2014-07-28 2016-10-18 Adobe Systems Incorporated Accelerating object detection
US10043101B2 (en) * 2014-11-07 2018-08-07 Adobe Systems Incorporated Local feature representation for image recognition
US10133927B2 (en) * 2014-11-14 2018-11-20 Sony Corporation Method and system for processing video content
KR20170090417A (en) * 2014-12-03 2017-08-07 소니 주식회사 Information processing apparatus, information processing method, and program
EP3231175B1 (en) 2015-04-29 2021-02-24 Hewlett-Packard Development Company, L.P. System and method for processing depth images which capture an interaction of an object relative to an interaction plane
US9916668B2 (en) 2015-05-19 2018-03-13 Personify, Inc. Methods and systems for identifying background in video data using geometric primitives
US9607397B2 (en) 2015-09-01 2017-03-28 Personify, Inc. Methods and systems for generating a user-hair-color model
CN107735800B (en) * 2016-02-04 2021-09-14 华为技术有限公司 Image processing method and related device
TWI622298B (en) * 2016-08-23 2018-04-21 和碩聯合科技股份有限公司 Advertisement image generation system and advertisement image generating method thereof
CN106548185B (en) * 2016-11-25 2019-05-24 三星电子(中国)研发中心 A kind of foreground area determines method and apparatus
CN107194949B (en) * 2017-05-18 2019-09-24 华中科技大学 A kind of interactive video dividing method and system matched based on block and enhance Onecut
JP7130348B2 (en) 2017-09-18 2022-09-05 エレメント,インク. Method, system and medium for detecting spoofing in mobile authentication
US10692220B2 (en) * 2017-10-18 2020-06-23 International Business Machines Corporation Object classification based on decoupling a background from a foreground of an image
US10685446B2 (en) * 2018-01-12 2020-06-16 Intel Corporation Method and system of recurrent semantic segmentation for image processing
EP3657514A1 (en) 2018-11-22 2020-05-27 Koninklijke Philips N.V. Interactive iterative image annotation
CN109784164B (en) * 2018-12-12 2020-11-06 北京达佳互联信息技术有限公司 Foreground identification method and device, electronic equipment and storage medium
US11343277B2 (en) 2019-03-12 2022-05-24 Element Inc. Methods and systems for detecting spoofing of facial recognition in connection with mobile devices
CN109978756B (en) * 2019-03-18 2021-03-09 腾讯科技(深圳)有限公司 Target detection method, system, device, storage medium and computer equipment
US11347965B2 (en) 2019-03-21 2022-05-31 Illumina, Inc. Training data generation for artificial intelligence-based sequencing
US11210554B2 (en) 2019-03-21 2021-12-28 Illumina, Inc. Artificial intelligence-based generation of sequencing metadata
US11593649B2 (en) 2019-05-16 2023-02-28 Illumina, Inc. Base calling using convolutions
US11423306B2 (en) 2019-05-16 2022-08-23 Illumina, Inc. Systems and devices for characterization and performance analysis of pixel-based sequencing
CN111882578A (en) * 2019-07-19 2020-11-03 广州虎牙科技有限公司 Foreground image acquisition method, foreground image acquisition device and electronic equipment
US11178311B2 (en) * 2019-08-21 2021-11-16 Adobe Inc. Context aware color reduction
GB2586512B (en) * 2019-08-23 2021-12-08 Dualitas Ltd Holographic projection
US11763565B2 (en) * 2019-11-08 2023-09-19 Intel Corporation Fine-grain object segmentation in video with deep features and multi-level graphical models
CN110838132B (en) * 2019-11-15 2022-08-05 北京字节跳动网络技术有限公司 Object segmentation method, device and equipment based on video stream and storage medium
US11398036B2 (en) 2019-11-19 2022-07-26 Snap Inc. World-space segmentation
US11507248B2 (en) 2019-12-16 2022-11-22 Element Inc. Methods, systems, and media for anti-spoofing using eye-tracking
CN115136244A (en) 2020-02-20 2022-09-30 因美纳有限公司 Many-to-many base interpretation based on artificial intelligence
US20220020113A1 (en) * 2020-07-15 2022-01-20 Instasize, Inc. Image resizing using seam carving
WO2022109000A1 (en) * 2020-11-17 2022-05-27 Uatc, Llc Systems and methods for video object segmentation
CN112601029B (en) * 2020-11-25 2023-01-03 上海卫莎网络科技有限公司 Video segmentation method, terminal and storage medium with known background prior information
US20220336054A1 (en) 2021-04-15 2022-10-20 Illumina, Inc. Deep Convolutional Neural Networks to Predict Variant Pathogenicity using Three-Dimensional (3D) Protein Structures
CN113408531B (en) * 2021-07-19 2023-07-14 北博(厦门)智能科技有限公司 Target object shape frame selection method and terminal based on image recognition
CN114222181B (en) * 2021-11-11 2024-03-12 北京达佳互联信息技术有限公司 Image processing method, device, equipment and medium
WO2023224436A1 (en) * 2022-05-20 2023-11-23 Samsung Electronics Co., Ltd. Systems and methods for encoding temporal information for video instance segmentation and object detection
WO2023244135A1 (en) * 2022-06-16 2023-12-21 Публичное Акционерное Общество "Сбербанк России" Method and system for segmenting scenes in a video sequence
CN116681715B (en) * 2023-08-04 2023-10-10 杭州脉流科技有限公司 Blood vessel segmentation method, device, equipment and storage medium based on pixel value change
CN117444990B (en) * 2023-12-25 2024-02-27 深圳市普朗医疗科技发展有限公司 Mechanical arm injection control method and system based on 3D modeling

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5875040A (en) * 1995-12-04 1999-02-23 Eastman Kodak Company Gradient based method for providing values for unknown pixels in a digital image
US6724915B1 (en) * 1998-03-13 2004-04-20 Siemens Corporate Research, Inc. Method for tracking a video object in a time-ordered sequence of image frames
US6912310B1 (en) 1999-06-10 2005-06-28 University Of Washington Video object segmentation using active contour model with directional information
US7242809B2 (en) 2003-06-25 2007-07-10 Microsoft Corporation Digital video segmentation and dynamic segment labeling
US7397935B2 (en) 2004-05-10 2008-07-08 Mediguide Ltd. Method for segmentation of IVUS image sequences
US7440589B2 (en) 2004-03-24 2008-10-21 Cernium Corporation Video analysis using segmentation gain by area
US7965875B2 (en) * 2006-06-12 2011-06-21 Tessera Technologies Ireland Limited Advances in extending the AAM techniques from grayscale to color images

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
DE3639117A1 (en) 1986-11-15 1988-05-19 Hoechst Ag (METH) ACRYLIC ACID ESTER
US6917692B1 (en) * 1999-05-25 2005-07-12 Thomson Licensing S.A. Kalman tracking of color objects
CN1784008B (en) * 2004-12-02 2010-04-28 北京凯诚高清电子技术有限公司 Encoding method and decoding method for high sharpness video super strong compression
CN100578508C (en) * 2008-01-14 2010-01-06 上海博康智能信息技术有限公司 Interactive type image search system and method
US8009184B2 (en) * 2008-06-13 2011-08-30 Zink Imaging, Inc. Thermal response correction system for multicolor printing
US8175379B2 (en) 2008-08-22 2012-05-08 Adobe Systems Incorporated Automatic video image segmentation

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5875040A (en) * 1995-12-04 1999-02-23 Eastman Kodak Company Gradient based method for providing values for unknown pixels in a digital image
US6724915B1 (en) * 1998-03-13 2004-04-20 Siemens Corporate Research, Inc. Method for tracking a video object in a time-ordered sequence of image frames
US6912310B1 (en) 1999-06-10 2005-06-28 University Of Washington Video object segmentation using active contour model with directional information
US7242809B2 (en) 2003-06-25 2007-07-10 Microsoft Corporation Digital video segmentation and dynamic segment labeling
US7440589B2 (en) 2004-03-24 2008-10-21 Cernium Corporation Video analysis using segmentation gain by area
US7397935B2 (en) 2004-05-10 2008-07-08 Mediguide Ltd. Method for segmentation of IVUS image sequences
US7965875B2 (en) * 2006-06-12 2011-06-21 Tessera Technologies Ireland Limited Advances in extending the AAM techniques from grayscale to color images

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
Apostoloff, et al., "Automatic Video Segmentation Using Spatiotemporal T-junctions," 2006.
Porikli, et al., "Automatic Video Object Segmentation Using Volume Growing and Hierarchical Clustering," EURASIP Journal on Applied Signal Processing 2004:6, pp. 814, 832, 2004 Hindawi Publishing Corporation.
Zhong, et al., "Interactive Tracker-A Semi-Automatic Video Object Tracking and Segmentation System," Microsoft Research China, IEEE, 2001, 4 pages.

Cited By (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8971584B2 (en) 2009-10-30 2015-03-03 Adobe Systems Incorporated Methods and apparatus for chatter reduction in video object segmentation using a variable bandwidth search region
US8358691B1 (en) * 2009-10-30 2013-01-22 Adobe Systems Incorporated Methods and apparatus for chatter reduction in video object segmentation using a variable bandwidth search region
US9628722B2 (en) 2010-03-30 2017-04-18 Personify, Inc. Systems and methods for embedding a foreground video into a background feed based on a control input
US10325360B2 (en) 2010-08-30 2019-06-18 The Board Of Trustees Of The University Of Illinois System for background subtraction with 3D camera
US9792676B2 (en) 2010-08-30 2017-10-17 The Board Of Trustees Of The University Of Illinois System for background subtraction with 3D camera
US20130251260A1 (en) * 2010-12-08 2013-09-26 Alcatel Lucent Method and system for segmenting an image
US9042662B2 (en) * 2010-12-08 2015-05-26 Alcatel Lucent Method and system for segmenting an image
US20130223732A1 (en) * 2012-02-28 2013-08-29 Brother Kogyo Kabushiki Kaisha Image processor capable of classifying original as color original quickly
US8929648B2 (en) * 2012-02-28 2015-01-06 Brother Kogyo Kabushiki Kaisha Image processor capable of classifying original as color original quickly
US9740916B2 (en) 2013-12-31 2017-08-22 Personify Inc. Systems and methods for persona identification using combined probability maps
US9485433B2 (en) 2013-12-31 2016-11-01 Personify, Inc. Systems and methods for iterative adjustment of video-capture settings based on identified persona
US9942481B2 (en) 2013-12-31 2018-04-10 Personify, Inc. Systems and methods for iterative adjustment of video-capture settings based on identified persona
US9342754B2 (en) * 2014-04-08 2016-05-17 Nokia Technologies Oy Image segmentation using blur and color
US9953223B2 (en) 2015-05-19 2018-04-24 Personify, Inc. Methods and systems for assigning pixels distance-cost values using a flood fill technique
US9563962B2 (en) 2015-05-19 2017-02-07 Personify, Inc. Methods and systems for assigning pixels distance-cost values using a flood fill technique
US9883155B2 (en) 2016-06-14 2018-01-30 Personify, Inc. Methods and systems for combining foreground video and background video using chromatic matching
US9881207B1 (en) 2016-10-25 2018-01-30 Personify, Inc. Methods and systems for real-time user extraction using deep learning networks
US10757346B1 (en) 2017-04-28 2020-08-25 Flixbay Technologies, Inc. Systems and methods for video extraction and insertion
US11800056B2 (en) 2021-02-11 2023-10-24 Logitech Europe S.A. Smart webcam system
US11659133B2 (en) 2021-02-24 2023-05-23 Logitech Europe S.A. Image generating system with background replacement or modification capabilities
US11800048B2 (en) 2021-02-24 2023-10-24 Logitech Europe S.A. Image generating system with background replacement or modification capabilities
US12058471B2 (en) 2021-02-24 2024-08-06 Logitech Europe S.A. Image generating system
WO2024026366A1 (en) * 2022-07-27 2024-02-01 Stryker Corporation Systems and methods for real-time processing of medical imaging data utilizing an external processing device

Also Published As

Publication number Publication date
CN101676953A (en) 2010-03-24
US20120213432A1 (en) 2012-08-23
US8422775B2 (en) 2013-04-16
US20100046830A1 (en) 2010-02-25
CN101676953B (en) 2012-08-29

Similar Documents

Publication Publication Date Title
US8175379B2 (en) Automatic video image segmentation
US8971584B2 (en) Methods and apparatus for chatter reduction in video object segmentation using a variable bandwidth search region
US8290253B1 (en) Method and apparatus for applying Gaussian Mixture Models to local image patches using an adaptive color lookup table
US11176381B2 (en) Video object segmentation by reference-guided mask propagation
CN110188760B (en) Image processing model training method, image processing method and electronic equipment
US10679351B2 (en) System and method for semantic segmentation of images
US9947077B2 (en) Video object tracking in traffic monitoring
Bai et al. Video snapcut: robust video object cutout using localized classifiers
US8611728B2 (en) Video matting based on foreground-background constraint propagation
US7869631B2 (en) Automatic skin color model face detection and mean-shift face tracking
US7634108B2 (en) Automated face enhancement
US8824808B2 (en) Methods and apparatus for automated facial feature localization
US20080136820A1 (en) Progressive cut: interactive object segmentation
US20100195870A1 (en) Tracking method and device adopting a series of observation models with different life spans
US20140003719A1 (en) Adaptive Trimap Propagation for Video Matting
US12136200B2 (en) Method and system for replacing scene text in a video sequence
Nguyen et al. A weakly supervised amodal segmenter with boundary uncertainty estimation
US20180247418A1 (en) Method and apparatus for object tracking and segmentation via background tracking
CN112614149A (en) Semantic synthesis method based on instance segmentation
Sun et al. Globally tuned cascade pose regression via back propagation with application in 2D face pose estimation and heart segmentation in 3D CT images
US12002266B2 (en) Graph-based video instance segmentation
Koochari et al. Exemplar-based video inpainting with large patches
KR102233515B1 (en) Method for tracking target object in video and learning method for tracking target in video
US20220309679A1 (en) System and method for real-time object detection in video
US20240321318A1 (en) Generating contextual transition effects in videos

Legal Events

Date Code Title Description
AS Assignment

Owner name: ADOBE SYSTEMS INCORPORATED,CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WANG, JUE;BAI, XUE;REEL/FRAME:021871/0888

Effective date: 20081119

Owner name: ADOBE SYSTEMS INCORPORATED, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WANG, JUE;BAI, XUE;REEL/FRAME:021871/0888

Effective date: 20081119

AS Assignment

Owner name: ADOBE SYSTEMS INCORPORATED,CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WANG, JUE;BAI, XUE;REEL/FRAME:023054/0823

Effective date: 20081119

Owner name: ADOBE SYSTEMS INCORPORATED, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:WANG, JUE;BAI, XUE;REEL/FRAME:023054/0823

Effective date: 20081119

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: ADOBE INC., CALIFORNIA

Free format text: CHANGE OF NAME;ASSIGNOR:ADOBE SYSTEMS INCORPORATED;REEL/FRAME:048867/0882

Effective date: 20181008

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12