US20130148913A1 - Method and systems for thumbnail generation, and corresponding computer program product - Google Patents
Method and systems for thumbnail generation, and corresponding computer program product Download PDFInfo
- Publication number
- US20130148913A1 US20130148913A1 US13/761,085 US201313761085A US2013148913A1 US 20130148913 A1 US20130148913 A1 US 20130148913A1 US 201313761085 A US201313761085 A US 201313761085A US 2013148913 A1 US2013148913 A1 US 2013148913A1
- Authority
- US
- United States
- Prior art keywords
- image
- memory
- memory location
- storing
- pointer
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 claims description 24
- 238000012545 processing Methods 0.000 description 8
- 238000005070 sampling Methods 0.000 description 6
- 238000013459 approach Methods 0.000 description 5
- 230000015556 catabolic process Effects 0.000 description 3
- 238000007796 conventional method Methods 0.000 description 3
- 230000006837 decompression Effects 0.000 description 3
- 238000006731 degradation reaction Methods 0.000 description 3
- 239000003550 marker Substances 0.000 description 3
- 230000008569 process Effects 0.000 description 3
- 230000008901 benefit Effects 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 238000001914 filtration Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 239000000463 material Substances 0.000 description 2
- 210000003813 thumb Anatomy 0.000 description 2
- 230000004075 alteration Effects 0.000 description 1
- 230000007423 decrease Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000006866 deterioration Effects 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000013139 quantization Methods 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T3/00—Geometric image transformations in the plane of the image
- G06T3/04—Context-preserving transformations, e.g. by using an importance map
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T1/00—General purpose image data processing
- G06T1/60—Memory management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T3/00—Geometric image transformations in the plane of the image
- G06T3/40—Scaling of whole images or parts thereof, e.g. expanding or contracting
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T9/00—Image coding
Definitions
- This disclosure relates to thumbnail generation.
- Thumbnail images are small images derived from larger images by sub-sampling.
- thumbnails is an ordinary feature of personal computers and a desired feature of other consumer electronic (CE) devices such as digital photo frames, digital cameras, mobile phones, multi-function printers, etc. These devices are equipped with a screen or other display unit allowing the user to preview and/or browse digital photos and digital pictures. Providing high-quality and short-time-consuming image thumbnail generation is quite helpful in these such devices.
- Digital photo previewing and browsing are exemplary of the applications involving decoding a digital image (typically in JPEG format) and resizing it in order to be displayed on a specific target screen, while taking into account quality and processing time constraints.
- thumbnail generation is addressed extensively in the scientific and technical literature including the patent literature.
- WO-A-94/22108, US-A-2006/242163, and U.S. Pat. Nos. 6,263,119 and 6,778,707, which are incorporated by reference, are exemplary of patent documents related to thumbnail generation.
- a first approach involves a sub-sampling procedure in the image pixel domain. After choosing a zoom-out factor, based upon the relative dimensions of the target screen and the original image, data is filtered to obtain the desired resolution. To that end, resizing is performed through a line-by-line scanning, once the original image has been completely decoded (i.e., brought back to the image pixel domain), which inherently requires a considerable amount of computational time.
- Another approach involves resolution scaling implemented using spatial frequency subsampling in the DCT or transform domain, during the image decoding step. For instance, a 8 ⁇ 8 DCT block can be sub-sampled using a scaling ratio selected out of ⁇ 1, 1 ⁇ 2, 1 ⁇ 4, 1 ⁇ 8 ⁇ thus filtering out the high frequencies. Smaller scaling ratios permit significantly faster decoding since fewer coefficients need to be processed and a simpler IDCT method can be used. For instance, when choosing a ratio equal to 1 ⁇ 8, only the DC component is considered. The remainder of the decoding process, including the de-quantization of the quantized AC coefficients and the IDCT, can be “skipped”. Resizing may thus become a very fast process as the number of coefficients to be processed decreases, while, however, the final result may fail to optimally fit to the target screen and its shape (e.g., aspect ratio).
- thumbnail caching into system mass storage (e.g., hard disk) or removable media (e.g., USB disk, SD card), which in any case involves writing files into the file system of the storage device.
- system mass storage e.g., hard disk
- removable media e.g., USB disk, SD card
- An embodiment of this disclosure provides an arrangement for generating image thumbnails without significant losses in quality while drastically reducing the processing time required.
- Another embodiment of this disclosure provides an arrangement for generating image thumbnails that can be cached transparently in user mass storage devices.
- An embodiment also relates to a corresponding system as well as a related computer program product, loadable in the memory of at least one computer and including software code portions for performing the steps of an embodiment of a method when the product is run on a computer.
- a computer program product is intended to be equivalent to reference to a computer-readable medium containing instructions for controlling a computer system to coordinate the performance of a method embodiment.
- Reference to “at least one computer” is intended to highlight the possibility for an embodiment to be implemented in a distributed/modular fashion.
- a method for the fast generation of a JPEG image thumbnail from the full-size JPEG image without producing visible quality deterioration.
- image-transition time on the screen of consumer electronics devices equipped with limited processing resources is reduced.
- An embodiment reduces the image size to a target size by operating directly in the spatial frequency domain, during a decompression stage, by first bringing image size as close as possible to the target size; size refinement, to substantially perfectly match target size, is then performed by spatial sub-sampling and/or over-sampling.
- a decompression stage takes much less time than full decompression since it operates only on certain frequencies, and at the same time reduces the original image size.
- spatial resizing when needed, processes a small amount of data.
- the image rendering time on a display device is reduced and made constant and independent of decoding time, by caching thumbnail data in a system memory (or in a user mass storage device, if the memory space available is insufficient, as may be the case in embedded systems).
- this limitation is overcome by writing data (e.g., into user mass-storage) without changing its file system data structures. In comparison with conventional methods, writing thumbnail data without altering file system data structures preserves file system integrity threatened by asynchronous user storage media removal.
- the arrangement herein provides high performance and is well suited for use in embedded systems and applications where image thumbnails are generated more often required than full images while computational resources are limited.
- Mobile and fixed consumer electronic devices such as PDA, mobile phones, digital photo frames, multi-function printers are exemplary of possible fields of use of this disclosure.
- FIG. 1 is an embodiment of DCT coefficient selection in an embodiment
- FIG. 2 is an embodiment of a Thumbnails Cache Table (TCT).
- FIGS. 3 and 4 are block diagrams of embodiments of thumbnail caching arrangements.
- An embodiment “mixes” image resizing methods operating in the spatial frequency domain (e.g., based on discrete trigonometric transforms) with image resizing methods operating in the image pixel domain.
- zoom is the computed ratio (smaller than unity) between thumbnail size and image size.
- T (thumbnail) and I (image) may have different aspect ratios (i.e., the width-to-height ratio), and avoiding geometrical distortion may be advantageous.
- the parameter zoom is computed as:
- spatial frequency domain resizing is exploited to quickly move towards the target size and subsequently matching it by re-sampling the IDCT output.
- z 1 is the zoom factor used in the spatial frequency domain resizing stage
- z 2 is the zoom factor used in the spatial (i.e., pixel) domain.
- Zooming out by values in z 1 corresponds to considering the lower frequency portions of the image during the IDCT decoding step.
- FIG. 1 shows IDCT filtering according to the corresponding DCT-coefficients-assembling technique.
- zoom factorization is performed by selecting a value for z 1 out of the set ⁇ 1 ⁇ 8, 1 ⁇ 4, 1 ⁇ 2, 1 ⁇ .
- this selection is based on the following rule:
- a rule for selecting the z 1 zoom factor may be applied leading to a z 2 zoom factor which is larger than or equal to one.
- the result of zoom-out via the z 1 zoom factor will in most instances be at least marginally “smaller” than the target thumbnail size, so that further zoom-in via the z 2 zoom factor will be applied to achieve the desired matching to the target size.
- the z 1 function considered in the foregoing may be re-arranged as follows:
- parameter q can vary between ⁇ 0.5, 1 ⁇ and has the effect to expand and move the z 1 function in a geometric fashion.
- the original image is zoomed out more than necessary.
- the parameter q affects the trade-off between image degradation and time performance of the whole method.
- values for q close to 1 typically do not introduce further image degradation, as in most cases, the image is only scaled down, but a less satisfactory time performance may ensue.
- reference 10 denotes a processor module including zooming processor features for JPEG thumbnail generation as described in the foregoing.
- a processor is a conventional zooming processor including processing resources adapted to perform thumbnail generation according to the conventional methods discussed in the introductory portion of this disclosure.
- the processor 10 is included in a consumer electronics device CE (e.g., any of the consumer electronics devices discussed in the introductory portion of this description).
- the processor 10 is configured for interacting with a display unit 12 and a memory 14 for storing (caching) thumbnail data related to thumbnails to be displayed in the unit 12 .
- the processor 10 may generate (i.e., calculate) thumbnails in advance for display as soon as required: e.g., while a current picture is being displayed, “next” thumbnail data is generated in the background and cached into a system memory, ready to be displayed on demand.
- certain embedded systems may not have sufficient memory resources to perform conventional thumbnail caching, while writing files into the file system of the storage device may result in corruption of the file system if the media is removed.
- An embodiment considered herein is file system safe, in that it caches thumbnails into free blocks of the file system, without identifying them as allocated space. In this way, file-system data structures are never modified, so that integrity is always guaranteed. This can be successfully accomplished if no writing access chooses one of these occupied (by a thumbnail) blocks on the storage device in the meantime. For instance, this condition may be achieved when multitasking is not implemented.
- bitmap used to track allocated blocks. After volume creation, the bitmap will indicate that most blocks are free, typically having all bits clear. As the file system is used in write mode, the bitmap is updated to indicate used storage blocks. In order to find free space for thumbnails caching, the method is made file system aware (i.e., the bitmap is checked so that thumbnails are written to unoccupied blocks), so that user data corruption is avoided.
- Images to be cached are chosen in an application-specific manner. For instance, in the case of an application supporting image browsing in n-up mode, it could be useful to have 3n thumbnails cached for the current, previous, and next page. Conversely, if an application supports only a slide-show mode, then the very next photo is cached.
- Thumbnail Cache Table (TCT) is allocated into the main memory. That table will be filled in and updated each time a new thumbnail is generated as shown in FIG. 2 .
- the File_ID field represents a unique image file identifier (e.g., path/filename)
- the First Block Address field represents a pointer to a first block of image thumbnail data.
- FIGS. 3 and 4 are exemplary of two approaches for storing thumbnails in the memory 14 .
- each thumbnail is stored as a linked list of storage blocks (designated “data”).
- the first bytes FB of each block are used as a pointer to the next one.
- the rest of the block is for data ended by EOF within the last block.
- FIG. 4 a tree-like arrangement is used where a first (“root”) block is used to store a sequence of pointers P 1 , P 2 , P 3 to blocks of data.
- the first block is not enough to store all the block pointers, its last address is used to point to a second block of block pointers, and so on.
- the sequence of pointers is ended with a special marker NULL that is not a valid block number. Again, the data is terminated with a special marker EOF.
- the number of thumbnails that can be cached (and hence the number of entries in the thumbnail cache table) may be obtained as a parameter designated cached thumbs by means of the following formula:
- the number of cached thumbs calculated as above can be possibly scaled down by other factors.
- the cache could be oversized if the processor has limited computation resources compared to application requirements, in which case the processor may be unable to fill the whole cache.
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Multimedia (AREA)
- Image Processing (AREA)
- Editing Of Facsimile Originals (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
An embodiment of a consumer electronics product having a thumbnail display feature includes a system for generating and storing thumbnails having a given size from images, such as JPEG images, for which a spatial frequency domain representation is available. The system includes a zooming processor to reduce the size of the images by zooming. The zooming processor is configured to perform both spatial frequency domain zooming to approximate the desired thumbnail size and then image pixel domain zooming to fit the desired thumbnail size. The product includes cache storage configured to store a plurality of thumbnails in a file system as free blocks in the file system, so that file system data structures are left unchanged.
Description
- This disclosure relates to thumbnail generation.
- This disclosure was devised by paying attention to its possible use in generating thumbnails for those images for which a representation is available in the spatial frequency domain; JPEG encoded images are exemplary of such images.
- Thumbnail images (or, briefly, “thumbnails”) are small images derived from larger images by sub-sampling.
- Generation of thumbnails is an ordinary feature of personal computers and a desired feature of other consumer electronic (CE) devices such as digital photo frames, digital cameras, mobile phones, multi-function printers, etc. These devices are equipped with a screen or other display unit allowing the user to preview and/or browse digital photos and digital pictures. Providing high-quality and short-time-consuming image thumbnail generation is quite helpful in these such devices. Digital photo previewing and browsing are exemplary of the applications involving decoding a digital image (typically in JPEG format) and resizing it in order to be displayed on a specific target screen, while taking into account quality and processing time constraints.
- Generation of thumbnails is addressed extensively in the scientific and technical literature including the patent literature. WO-A-94/22108, US-A-2006/242163, and U.S. Pat. Nos. 6,263,119 and 6,778,707, which are incorporated by reference, are exemplary of patent documents related to thumbnail generation.
- So far, two basic approaches have been resorted to for thumbnail generation.
- A first approach involves a sub-sampling procedure in the image pixel domain. After choosing a zoom-out factor, based upon the relative dimensions of the target screen and the original image, data is filtered to obtain the desired resolution. To that end, resizing is performed through a line-by-line scanning, once the original image has been completely decoded (i.e., brought back to the image pixel domain), which inherently requires a considerable amount of computational time.
- Another approach involves resolution scaling implemented using spatial frequency subsampling in the DCT or transform domain, during the image decoding step. For instance, a 8×8 DCT block can be sub-sampled using a scaling ratio selected out of {1, ½, ¼, ⅛} thus filtering out the high frequencies. Smaller scaling ratios permit significantly faster decoding since fewer coefficients need to be processed and a simpler IDCT method can be used. For instance, when choosing a ratio equal to ⅛, only the DC component is considered. The remainder of the decoding process, including the de-quantization of the quantized AC coefficients and the IDCT, can be “skipped”. Resizing may thus become a very fast process as the number of coefficients to be processed decreases, while, however, the final result may fail to optimally fit to the target screen and its shape (e.g., aspect ratio).
- Additionally, certain systems such as certain embedded systems may not have sufficient memory resources to perform thumbnail caching as conventionally described in the literature, namely thumbnail caching into system mass storage (e.g., hard disk) or removable media (e.g., USB disk, SD card), which in any case involves writing files into the file system of the storage device. When removable mass-storage is used, if the media is abruptly removed during the write stage, file system corruption may occur.
- An embodiment of this disclosure provides an arrangement for generating image thumbnails without significant losses in quality while drastically reducing the processing time required.
- Another embodiment of this disclosure provides an arrangement for generating image thumbnails that can be cached transparently in user mass storage devices.
- An embodiment also relates to a corresponding system as well as a related computer program product, loadable in the memory of at least one computer and including software code portions for performing the steps of an embodiment of a method when the product is run on a computer. As used herein, reference to such a computer program product is intended to be equivalent to reference to a computer-readable medium containing instructions for controlling a computer system to coordinate the performance of a method embodiment. Reference to “at least one computer” is intended to highlight the possibility for an embodiment to be implemented in a distributed/modular fashion.
- In an embodiment, a method is provided for the fast generation of a JPEG image thumbnail from the full-size JPEG image without producing visible quality deterioration.
- In an embodiment, image-transition time on the screen of consumer electronics devices equipped with limited processing resources is reduced.
- An embodiment reduces the image size to a target size by operating directly in the spatial frequency domain, during a decompression stage, by first bringing image size as close as possible to the target size; size refinement, to substantially perfectly match target size, is then performed by spatial sub-sampling and/or over-sampling. In comparison with conventional methods, a decompression stage takes much less time than full decompression since it operates only on certain frequencies, and at the same time reduces the original image size. Moreover, spatial resizing, when needed, processes a small amount of data.
- In an embodiment, the image rendering time on a display device is reduced and made constant and independent of decoding time, by caching thumbnail data in a system memory (or in a user mass storage device, if the memory space available is insufficient, as may be the case in embedded systems). In an embodiment, this limitation is overcome by writing data (e.g., into user mass-storage) without changing its file system data structures. In comparison with conventional methods, writing thumbnail data without altering file system data structures preserves file system integrity threatened by asynchronous user storage media removal.
- The arrangement herein provides high performance and is well suited for use in embedded systems and applications where image thumbnails are generated more often required than full images while computational resources are limited. Mobile and fixed consumer electronic devices (such as PDA, mobile phones, digital photo frames, multi-function printers) are exemplary of possible fields of use of this disclosure.
- One or more embodiments will now be described, by way of example only, with reference to the enclosed figures of drawing, wherein:
-
FIG. 1 is an embodiment of DCT coefficient selection in an embodiment; -
FIG. 2 is an embodiment of a Thumbnails Cache Table (TCT); and -
FIGS. 3 and 4 are block diagrams of embodiments of thumbnail caching arrangements. - In the following description, numerous specific details are given to provide a thorough understanding of embodiments. The embodiments can be practiced without one or more of the specific details, or with other methods, components, materials, etc. In other instances, well-known structures, materials, or operations are not shown or described in detail to avoid obscuring aspects of the embodiments.
- Reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. Thus, the appearances of the phrases “in one embodiment” or “in an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures, or characteristics may be combined in any suitable manner in one or more embodiments.
- The headings provided herein are for convenience only and do not limit the scope or meaning of the embodiments.
- An embodiment “mixes” image resizing methods operating in the spatial frequency domain (e.g., based on discrete trigonometric transforms) with image resizing methods operating in the image pixel domain.
- Assuming that I is the original size image, its thumbnail T can be represented by the following geometrical transformation
-
T=G(zoom,I) - where zoom is the computed ratio (smaller than unity) between thumbnail size and image size.
- Since T (thumbnail) and I (image) may have different aspect ratios (i.e., the width-to-height ratio), and avoiding geometrical distortion may be advantageous, the parameter zoom is computed as:
- min{(thumbnail_width/image_width), (thumbnail_height/image_height)}
where min { } denotes the minimum of the two thumbnail- to-image width and height ratios. - In an embodiment, spatial frequency domain resizing is exploited to quickly move towards the target size and subsequently matching it by re-sampling the IDCT output.
- Thus a zoom factor factorization is required, so that:
-
ZOOM=z 1 ·z 2 - where
- z1 is the zoom factor used in the spatial frequency domain resizing stage, and
- z2 is the zoom factor used in the spatial (i.e., pixel) domain.
- In addressing the issue of zoom factorization, it may be worth mentioning that spatial frequency zoom-out involves “power of two” factors i.e., 2k, so that valid values for z1 are, e.g., in the set z1={⅛, ¼, ½, 1}.
- Zooming out by values in z1 corresponds to considering the lower frequency portions of the image during the IDCT decoding step.
- In particular, in the case of z1={⅛, ¼, ½, 1} 1×1, 2×2, 4×4 and 8×8 (full) sub-blocks of DCT coefficients are taken into account, respectively.
FIG. 1 shows IDCT filtering according to the corresponding DCT-coefficients-assembling technique. - In this case, zoom factorization is performed by selecting a value for z1 out of the set {⅛, ¼, ½, 1}.
- In the embodiment to which
FIG. 1 refers, this selection is based on the following rule: -
z 1=1/k if (½k)<zoom≦(1/k) k=1,2,4 -
z 1=⅛ if zoom≦(⅛) - This rule leads to a z2 zoom factor (calculated as z2=zoom/z1) which is smaller than or equal to one. This means that, when not already achieved (as is more often the case) via the z1 zoom factor only, target size matching is achieved via further zoom-out via the z2 zoom factor. In that case, the result of zoom-out via the z1 zoom factor will in most instances be at least marginally “larger” than the target thumbnail size, so that further zoom-out via the z2 zoom factor will be applied to achieve the desired matching to the target size.
- It will be appreciated that a rule for selecting the z1 zoom factor may be applied leading to a z2 zoom factor which is larger than or equal to one. In that case, the result of zoom-out via the z1 zoom factor will in most instances be at least marginally “smaller” than the target thumbnail size, so that further zoom-in via the z2 zoom factor will be applied to achieve the desired matching to the target size.
- For instance, in order to take further advantage of spatial frequency down-sampling, the z1 function considered in the foregoing may be re-arranged as follows:
-
z 1=1/k if (½qk)<zoom≦(1/qk) k=1,2,4 -
z 1=⅛ if zoom≦(1/q8) - where the parameter q can vary between {0.5, 1} and has the effect to expand and move the z1 function in a geometric fashion.
- In other words, under a specified threshold, the original image is zoomed out more than necessary. When this occurs, the z2 zoom factor (again calculated as z2=zoom/z1) becomes larger than one, and a zoom-in processing is performed in order to achieve the desired target size.
- The parameter q affects the trade-off between image degradation and time performance of the whole method.
- Values for q close to 0.5 lead to time performance improvements (i.e., thumbnail generation is quicker), but introduce more image degradation in comparison with direct zooming, in that the image is first scaled down and then scaled up (other than in the case where zoom<⅛).
- Conversely, values for q close to 1 typically do not introduce further image degradation, as in most cases, the image is only scaled down, but a less satisfactory time performance may ensue.
- In both
FIGS. 3 and 4 ,reference 10 denotes a processor module including zooming processor features for JPEG thumbnail generation as described in the foregoing. In an embodiment, such a processor is a conventional zooming processor including processing resources adapted to perform thumbnail generation according to the conventional methods discussed in the introductory portion of this disclosure. - In the embodiments considered, the
processor 10 is included in a consumer electronics device CE (e.g., any of the consumer electronics devices discussed in the introductory portion of this description). Theprocessor 10 is configured for interacting with adisplay unit 12 and amemory 14 for storing (caching) thumbnail data related to thumbnails to be displayed in theunit 12. - The
processor 10 is programmed (in a manner known per se) to implement the zoom=z1. z2 processing discussed in the foregoing. Such zoom=z1. z2 processing entails advantages in terms of quality v. processing time/resources discussed previously. - Especially in low-capacity embedded systems, instantaneously refreshing images on an associated display device may be a critical factor. For that reason, once a first thumbnail has been generated, the
processor 10 may generate (i.e., calculate) thumbnails in advance for display as soon as required: e.g., while a current picture is being displayed, “next” thumbnail data is generated in the background and cached into a system memory, ready to be displayed on demand. - As already indicated, certain embedded systems may not have sufficient memory resources to perform conventional thumbnail caching, while writing files into the file system of the storage device may result in corruption of the file system if the media is removed.
- An embodiment considered herein is file system safe, in that it caches thumbnails into free blocks of the file system, without identifying them as allocated space. In this way, file-system data structures are never modified, so that integrity is always guaranteed. This can be successfully accomplished if no writing access chooses one of these occupied (by a thumbnail) blocks on the storage device in the meantime. For instance, this condition may be achieved when multitasking is not implemented.
- In order to exemplify such an approach, one may think of generic file system metadata as a bitmap used to track allocated blocks. After volume creation, the bitmap will indicate that most blocks are free, typically having all bits clear. As the file system is used in write mode, the bitmap is updated to indicate used storage blocks. In order to find free space for thumbnails caching, the method is made file system aware (i.e., the bitmap is checked so that thumbnails are written to unoccupied blocks), so that user data corruption is avoided.
- For instance, a fixed number of image thumbnails may be cached. Images to be cached are chosen in an application-specific manner. For instance, in the case of an application supporting image browsing in n-up mode, it could be useful to have 3n thumbnails cached for the current, previous, and next page. Conversely, if an application supports only a slide-show mode, then the very next photo is cached.
- Once available free blocks have been found, a Thumbnail Cache Table (TCT) is allocated into the main memory. That table will be filled in and updated each time a new thumbnail is generated as shown in
FIG. 2 . There, the File_ID field represents a unique image file identifier (e.g., path/filename) and the First Block Address field represents a pointer to a first block of image thumbnail data. -
FIGS. 3 and 4 are exemplary of two approaches for storing thumbnails in thememory 14. - In
FIG. 3 , each thumbnail is stored as a linked list of storage blocks (designated “data”). - The first bytes FB of each block are used as a pointer to the next one. The rest of the block is for data ended by EOF within the last block. The list is terminated with a special marker that is not a valid block number File_ID (FB=NULL for the last block in the list).
- In
FIG. 4 , a tree-like arrangement is used where a first (“root”) block is used to store a sequence of pointers P1, P2, P3 to blocks of data. - If the first block is not enough to store all the block pointers, its last address is used to point to a second block of block pointers, and so on.
- The sequence of pointers is ended with a special marker NULL that is not a valid block number. Again, the data is terminated with a special marker EOF.
- The number of thumbnails that can be cached (and hence the number of entries in the thumbnail cache table) may be obtained as a parameter designated cached thumbs by means of the following formula:
- min{(freedisk_space/thumbnail_size),
(free_RAM_space/TCT_record_size), JPEG_files} - where min { } again denotes the minimum operator and where:
-
- free_disk_space is the available space within user mass storage; this may be calculated, e.g., by parsing the file system metadata;
- thumbnail_size is derived from the display resolution and its color depth; this size takes into account also the block-pointers overhead (i.e., the amount of memory occupied by the pointers FB or P1, . . . , Pn);
- free_RAM_space represents the amount of free main memory that can be dedicated to the allocation of Thumbnails Cache Table;
- TCT_record_size is the dimension of a single TCT entry; and
- JPEG_files is simply the number of pictures on the user mass storage.
- The number of cached thumbs calculated as above can be possibly scaled down by other factors. For instance, the cache could be oversized if the processor has limited computation resources compared to application requirements, in which case the processor may be unable to fill the whole cache.
- Without prejudice to the underlying principles of the disclosure, the details and the embodiments may vary, even appreciably, with respect to what has been described by way of example only, without departing from the spirit and scope of the disclosure.
- Naturally, in order to satisfy local and specific requirements, a person skilled in the art may apply to the embodiments described above many modifications and alterations. Particularly, although one or more embodiments have been described with a certain degree of particularity, it should be understood that various omissions, substitutions, and changes in the form and details as well as other embodiments are possible. Moreover, it is expressly intended that specific elements and/or method steps described in connection with any disclosed embodiment may be incorporated in any other embodiment as a general matter of design choice.
Claims (17)
1-58. (canceled)
59. A method, comprising:
storing in a first memory location an image identifier and a pointer to a second memory location; and
storing in the second memory location a pointer to a third memory location that stores at least a first portion of the image corresponding to the image identifier.
60. The method of claim 59 , further comprising storing in the second memory location at least a second portion of the image corresponding to the image identifier.
61. The method of claim 59 , further comprising storing in the second memory location a pointer to a fourth memory location that stores at least a second portion of the image.
62. The method of claim 59 , further comprising storing in the third memory location a pointer to a fourth memory location that stores at least a second portion of the image.
63. The method of claim 59 , further comprising storing in the second memory location a pointer to a fourth memory location that stores at least a second portion of the image and a value indicating an end of the image.
64. The method of claim 59 , further comprising storing in the second memory location a pointer to a fourth memory location that stores a value indicating an end of the image.
65. The method of claim 59 , further comprising storing in the second memory location after the pointer a value indicating that there are no additional pointers in the second memory.
66. The method of claim 59 , further comprising storing in the third memory location a pointer that points to a fourth memory location via at least one other memory location, the fourth memory location storing a value indicating an end of the image.
67. The method of claim 59 , further comprising storing in the third memory location a pointer that points to a fourth memory location via at least one other memory location, the fourth memory location storing at least a second portion of the image and a value indicating an end of the image.
68. A system, comprising:
a memory;
a processor coupled to the memory and operable
to store in a first location of the memory an image identifier and a pointer to a second location of the memory; and
to store in the second location of the memory a pointer to a third location of the memory that stores at least a first portion of the image corresponding to the image identifier.
69. The system of claim 68 wherein the memory and the processor are disposed on a same integrated-circuit die.
70. The system of claim 68 wherein the memory and the processor are disposed on respective integrated-circuit dies.
71. The system of claim 68 , wherein the first portion corresponds to a spatial frequency domain factor.
72. The system of claim 68 , wherein the first portion corresponds to an image pixel domain factor.
73. The system of claim 68 , further comprising a cache storage in the memory configured to store the image in a file system as a free block such that file system data structures are left unchanged.
74. The system of claim 68 , further comprising a cache storage in the memory configured to store the image as a linked list of storage blocks.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/761,085 US9652818B2 (en) | 2009-04-30 | 2013-02-06 | Method and systems for thumbnail generation, and corresponding computer program product |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/433,276 US9076239B2 (en) | 2009-04-30 | 2009-04-30 | Method and systems for thumbnail generation, and corresponding computer program product |
US13/761,085 US9652818B2 (en) | 2009-04-30 | 2013-02-06 | Method and systems for thumbnail generation, and corresponding computer program product |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/433,276 Division US9076239B2 (en) | 2009-04-30 | 2009-04-30 | Method and systems for thumbnail generation, and corresponding computer program product |
Publications (2)
Publication Number | Publication Date |
---|---|
US20130148913A1 true US20130148913A1 (en) | 2013-06-13 |
US9652818B2 US9652818B2 (en) | 2017-05-16 |
Family
ID=43030397
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/433,276 Expired - Fee Related US9076239B2 (en) | 2009-04-30 | 2009-04-30 | Method and systems for thumbnail generation, and corresponding computer program product |
US13/759,991 Expired - Fee Related US9105111B2 (en) | 2009-04-30 | 2013-02-05 | Method and systems for thumbnail generation, and corresponding computer program product |
US13/761,085 Active 2029-07-10 US9652818B2 (en) | 2009-04-30 | 2013-02-06 | Method and systems for thumbnail generation, and corresponding computer program product |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/433,276 Expired - Fee Related US9076239B2 (en) | 2009-04-30 | 2009-04-30 | Method and systems for thumbnail generation, and corresponding computer program product |
US13/759,991 Expired - Fee Related US9105111B2 (en) | 2009-04-30 | 2013-02-05 | Method and systems for thumbnail generation, and corresponding computer program product |
Country Status (1)
Country | Link |
---|---|
US (3) | US9076239B2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9105111B2 (en) | 2009-04-30 | 2015-08-11 | Stmicroelectronics S.R.L. | Method and systems for thumbnail generation, and corresponding computer program product |
Families Citing this family (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR101638190B1 (en) * | 2009-08-19 | 2016-07-20 | 삼성전자주식회사 | Apparatus and method of digital media server's contents flip listing caching using user input feedback |
CN103092833A (en) * | 2011-10-27 | 2013-05-08 | 腾讯科技(深圳)有限公司 | Method, apparatus and mobile device for viewing pictures in mobile browser |
KR101945830B1 (en) * | 2012-05-24 | 2019-06-11 | 삼성전자 주식회사 | Method and apparatus for multi-playing videos |
US8957908B2 (en) | 2012-07-16 | 2015-02-17 | International Business Machines Corporation | Rapid representational thumbnail images for business intelligence dashboards |
US20150324088A1 (en) * | 2014-05-09 | 2015-11-12 | Lyve Minds, Inc. | Thumbnail image creation |
US9916251B2 (en) * | 2014-12-01 | 2018-03-13 | Samsung Electronics Co., Ltd. | Display driving apparatus and cache managing method thereof |
CN106251283A (en) * | 2016-07-28 | 2016-12-21 | 乐视控股(北京)有限公司 | A kind of reduced graph generating method and equipment |
US11222398B2 (en) | 2017-08-28 | 2022-01-11 | Microsoft Technology Licensing, Llc | Multiple thumbnails for attachments in electronic communications |
JP2021174404A (en) * | 2020-04-28 | 2021-11-01 | 株式会社Preferred Networks | Data generation device, training device, and data generation method |
Citations (56)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5761655A (en) * | 1990-06-06 | 1998-06-02 | Alphatronix, Inc. | Image file storage and retrieval system |
US6002794A (en) * | 1996-04-08 | 1999-12-14 | The Trustees Of Columbia University The City Of New York | Encoding and decoding of color digital image using wavelet and fractal encoding |
US6067068A (en) * | 1996-04-16 | 2000-05-23 | Canon Business Machines, Inc. | Scrollable display window |
US20010037433A1 (en) * | 2000-05-15 | 2001-11-01 | Superspeed.Com, Inc. | System and method for high-speed substitute cache |
US20020000998A1 (en) * | 1997-01-09 | 2002-01-03 | Paul Q. Scott | Thumbnail manipulation using fast and aspect ratio zooming, compressing and scaling |
US6418489B1 (en) * | 1999-10-25 | 2002-07-09 | Motorola, Inc. | Direct memory access controller and method therefor |
US20020103970A1 (en) * | 2000-08-15 | 2002-08-01 | Gut Ron Abraham | Cache system and method for generating uncached objects from cached and stored object components |
US20020172225A1 (en) * | 2001-05-21 | 2002-11-21 | Oon-Sim Ang | Clock signal decoupling for synchronous operation |
US20030074525A1 (en) * | 2001-10-17 | 2003-04-17 | Fujitsu Limited | Cache control program and computer for performing cache processes |
US20030133007A1 (en) * | 1997-10-21 | 2003-07-17 | Katsumi Iijima | Image pickup apparatus |
US20030188121A1 (en) * | 2002-03-27 | 2003-10-02 | Sumit Roy | Efficiency in a memory management system |
US20030206661A1 (en) * | 2001-02-15 | 2003-11-06 | Schwartz Edward L. | Method and apparatus for clipping coefficient values after application of each wavelet transform |
US6670934B1 (en) * | 1999-02-03 | 2003-12-30 | William H. Gates, III | Method and system for distributing art |
US20040001631A1 (en) * | 2002-06-28 | 2004-01-01 | Microsoft Corporation | Generation of metadata for acquired images |
US20040165789A1 (en) * | 2002-12-13 | 2004-08-26 | Yasuhiro Ii | Method of displaying a thumbnail image, server computer, and client computer |
US20040205629A1 (en) * | 2001-08-08 | 2004-10-14 | Rosenholtz Ruth E. | Methods and systems for generating enhanced thumbnails usable for document navigation |
US20040205627A1 (en) * | 2001-08-08 | 2004-10-14 | Rosenholtz Ruth E. | Methods and systems for generating enhanced thumbnails |
US20040236897A1 (en) * | 2003-05-19 | 2004-11-25 | Chi-Chih Cheng | System and method for optimized access to memory devices requiring block writing |
US6879981B2 (en) * | 2001-01-16 | 2005-04-12 | Corigin Ltd. | Sharing live data with a non cooperative DBMS |
US20050259163A1 (en) * | 2004-05-18 | 2005-11-24 | Canon Kabushiki Kaisha | Information recording apparatus and control method thereof |
US20060107289A1 (en) * | 2004-07-28 | 2006-05-18 | Microsoft Corporation | Thumbnail generation and presentation for recorded TV programs |
US7190806B2 (en) * | 2002-08-30 | 2007-03-13 | Hewlett-Packard Development Company, L.P. | System and method for data encryption/decryption |
US20070081744A1 (en) * | 2005-05-09 | 2007-04-12 | Gokturk Salih B | System and method for use of images with recognition analysis |
US20070177822A1 (en) * | 2006-01-30 | 2007-08-02 | Brother Kogyo Kabushiki Kaisha | Removable medium device, medium for controlling removable medium device, and medium for controlling network device |
US20070237414A1 (en) * | 2006-02-23 | 2007-10-11 | Nam-Ik Cho | Method and apparatus for resizing images using discrete cosine transform |
US7287088B1 (en) * | 2000-10-06 | 2007-10-23 | Fotomedia Technologies, Llc | Transmission bandwidth and memory requirements reduction in a portable image capture device by eliminating duplicate image transmissions |
US20070273702A1 (en) * | 2006-05-24 | 2007-11-29 | Nec Display Solutions, Ltd. | Image displaying device having image cache memory |
US20080005128A1 (en) * | 2006-06-30 | 2008-01-03 | Samsung Electronics., Ltd. | Method and system for addition of video thumbnail |
US20080209154A1 (en) * | 2007-02-28 | 2008-08-28 | Schneider James P | Page oriented memory management |
US7426734B2 (en) * | 2003-10-24 | 2008-09-16 | Microsoft Corporation | Facilitating presentation functionality through a programming interface media namespace |
US20080229237A1 (en) * | 2003-06-19 | 2008-09-18 | International Business Machines Corporation | System and computer-readable medium for ordering on-screen windows for display field of the invention |
US20080297532A1 (en) * | 2007-05-30 | 2008-12-04 | Microsoft Corporation | Rotation and scaling optimization for mobile devices |
US20100049754A1 (en) * | 2008-08-21 | 2010-02-25 | Hitachi, Ltd. | Storage system and data management method |
US20100082774A1 (en) * | 2005-09-09 | 2010-04-01 | Pitts William M | Distributed File System Consistency Mechanism Extension for Enabling Internet Video Broadcasting |
US20100111429A1 (en) * | 2007-12-07 | 2010-05-06 | Wang Qihong | Image processing apparatus, moving image reproducing apparatus, and processing method and program therefor |
US20100146016A1 (en) * | 2008-10-31 | 2010-06-10 | Nokia Corporation | Method and apparatus for file association |
US20100199024A1 (en) * | 2009-02-03 | 2010-08-05 | Samsung Electronics Co., Ltd. | Method and apparatus for managing data of flash memory via address mapping |
US7774541B2 (en) * | 2005-12-27 | 2010-08-10 | Samsung Electronics Co., Ltd. | Storage apparatus using non-volatile memory as cache and method of managing the same |
US20100278443A1 (en) * | 2009-04-30 | 2010-11-04 | Stmicroelectronics S.R.L. | Method and systems for thumbnail generation, and corresponding computer program product |
US20110182502A1 (en) * | 2010-01-22 | 2011-07-28 | Corel Corporation | Method of Content Aware Image Resizing |
US20110229057A1 (en) * | 2000-12-01 | 2011-09-22 | Nikon Corporation | Image data processing device |
US8046674B2 (en) * | 2001-10-31 | 2011-10-25 | Hewlett-Packard Development Company, L.P. | Internet browsing system |
US8365081B1 (en) * | 2009-05-28 | 2013-01-29 | Amazon Technologies, Inc. | Embedding metadata within content |
US20130067138A1 (en) * | 2011-09-09 | 2013-03-14 | Ocz Technology Group Inc. | Non-volatile memory-based mass storage devices and methods for writing data thereto |
US8577157B2 (en) * | 2004-07-08 | 2013-11-05 | Canon Kabushiki Kaisha | Conditional replenishment for motion JPEG2000 |
US20140053206A1 (en) * | 2012-08-17 | 2014-02-20 | Flextronics Ap, Llc | Thumbnail Cache |
US20140064635A1 (en) * | 2012-09-01 | 2014-03-06 | Garrett M Johnson | Grain Effect |
US8769031B1 (en) * | 2013-04-15 | 2014-07-01 | Upfront Media Group, Inc. | System and method for implementing a subscription-based social media platform |
US8793684B2 (en) * | 2011-03-16 | 2014-07-29 | International Business Machines Corporation | Optimized deployment and replication of virtual machines |
US8793290B1 (en) * | 2010-02-24 | 2014-07-29 | Toshiba Corporation | Metadata management for pools of storage disks |
US8812450B1 (en) * | 2011-04-29 | 2014-08-19 | Netapp, Inc. | Systems and methods for instantaneous cloning |
US20140359382A1 (en) * | 2013-06-03 | 2014-12-04 | Shin-Ho Choi | Memory controller and operating method providing replacement block for bad block |
US20140369614A1 (en) * | 2011-12-20 | 2014-12-18 | Imagination Technologies, Ltd. | Method and apparatus for compressing and decompressing data |
US9009763B2 (en) * | 2013-02-15 | 2015-04-14 | Cox Communications, Inc. | Content management in a cloud-enabled network-based digital video recorder |
US9369406B2 (en) * | 2014-07-03 | 2016-06-14 | Sas Institute Inc. | Resource server providing a rapidly changing resource |
US9450934B2 (en) * | 2013-03-15 | 2016-09-20 | Cox Communications, Inc. | Managed access to content and services |
Family Cites Families (71)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO1994022108A1 (en) | 1993-03-23 | 1994-09-29 | Zoran Corporation | Rapid thumbnail image reconstruction of dct compressed image data |
US5872874A (en) | 1995-04-26 | 1999-02-16 | Hewlett-Packard Company | Method and apparatus for scaling down images that are provided in a compressed data format |
US5845015A (en) * | 1995-10-12 | 1998-12-01 | Sarnoff Corporation | Method and apparatus for resizing images using the discrete cosine transform |
US5893116A (en) * | 1996-09-30 | 1999-04-06 | Novell, Inc. | Accessing network resources using network resource replicator and captured login script for use when the computer is disconnected from the network |
JPH10191341A (en) | 1996-12-24 | 1998-07-21 | Toshiba Corp | Image expansion device |
US6121969A (en) * | 1997-07-29 | 2000-09-19 | The Regents Of The University Of California | Visual navigation in perceptual databases |
EP0910042A3 (en) | 1997-10-17 | 2000-03-08 | Sony Corporation | Method and apparatus for encoding or decoding digital video data |
JP3556859B2 (en) * | 1998-09-08 | 2004-08-25 | 富士写真フイルム株式会社 | Image correction method, image correction device, and recording medium |
US6708309B1 (en) * | 1999-03-11 | 2004-03-16 | Roxio, Inc. | Method and system for viewing scalable documents |
US7236637B2 (en) * | 1999-11-24 | 2007-06-26 | Ge Medical Systems Information Technologies, Inc. | Method and apparatus for transmission and display of a compressed digitized image |
US6778707B1 (en) * | 1999-12-17 | 2004-08-17 | Xerox Corporation | Method for decompressing JPEG files using a variable block size inverse discrete cosine transform |
JP2001209470A (en) * | 2000-01-26 | 2001-08-03 | Fujitsu Ltd | Display interface method and apparatus, and program storage medium |
JP2002183167A (en) * | 2000-12-14 | 2002-06-28 | Canon Inc | Data communication device and image storage system |
US7679774B2 (en) * | 2001-04-06 | 2010-03-16 | Oce Printing Systems Gmbh | Method, system and computer program for the generation of an electronic document from scanned image data |
AUPS271002A0 (en) | 2002-05-31 | 2002-06-20 | Canon Kabushiki Kaisha | Embedding a multiresolution compressed thumbnail image in a compressed image file |
US7054496B2 (en) | 2002-06-27 | 2006-05-30 | Seiko Epson Corporation | Method and apparatus for displaying arbitrarily magnified high resolution images using compressed domain processing |
JP4244572B2 (en) * | 2002-07-04 | 2009-03-25 | ソニー株式会社 | Cache device, cache data management method, and computer program |
TWI242362B (en) | 2002-07-30 | 2005-10-21 | Sony Corp | Storage device, signal processor, image signal processor, and their methods |
JP4253498B2 (en) * | 2002-12-09 | 2009-04-15 | オリンパス株式会社 | Image search program, storage medium storing the program, image search device, and image search method |
FR2849982B1 (en) | 2003-01-15 | 2005-04-08 | Canon Kk | DECODING AN ENCODED DIGITAL IMAGE ACCORDING TO MULTIPLE LEVELS OF RESOLUTION |
US7272258B2 (en) * | 2003-01-29 | 2007-09-18 | Ricoh Co., Ltd. | Reformatting documents using document analysis information |
US7113543B2 (en) | 2003-02-03 | 2006-09-26 | Texas Instruments Incorporated | Video encoding |
JP2006520044A (en) | 2003-03-06 | 2006-08-31 | コーニンクレッカ フィリップス エレクトロニクス エヌ ヴィ | Data processing system with cache optimized for processing data flow applications |
KR20050116810A (en) | 2003-03-06 | 2005-12-13 | 코닌클리즈케 필립스 일렉트로닉스 엔.브이. | Data processing system with prefetching means |
DE602004008763T2 (en) | 2003-04-17 | 2008-06-12 | Koninklijke Philips Electronics N.V. | VIDEO TRANS CODING |
JP4617644B2 (en) | 2003-07-18 | 2011-01-26 | ソニー株式会社 | Encoding apparatus and method |
US7248753B2 (en) * | 2003-07-31 | 2007-07-24 | Kyocera Mita Corporation | Image displaying apparatus and program product for displaying image |
TWI237494B (en) | 2003-09-03 | 2005-08-01 | Mediatek Inc | Method and related apparatus for jpeg image decoding |
US7724827B2 (en) * | 2003-09-07 | 2010-05-25 | Microsoft Corporation | Multi-layer run level encoding and decoding |
US7864352B2 (en) * | 2003-09-25 | 2011-01-04 | Ricoh Co. Ltd. | Printer with multimedia server |
US20050134945A1 (en) * | 2003-12-17 | 2005-06-23 | Canon Information Systems Research Australia Pty. Ltd. | 3D view for digital photograph management |
US7609305B2 (en) | 2004-04-06 | 2009-10-27 | Samsung Electronics Co., Ltd. | Methods and systems for anti shading correction in image sensors |
JP2006025123A (en) | 2004-07-07 | 2006-01-26 | Olympus Corp | Image processor |
CN100417226C (en) | 2004-10-06 | 2008-09-03 | 日本电信电话株式会社 | Scalable encoding method and device, and scalable decoding method and device |
JP2006148731A (en) * | 2004-11-24 | 2006-06-08 | Sony Corp | Recording apparatus and method, reproducing apparatus and method, program, and recording medium |
JP2006191159A (en) * | 2004-12-28 | 2006-07-20 | Canon Inc | Method and apparatus for image processing |
PT1861809E (en) | 2005-03-14 | 2009-09-24 | Gtech Corp | System and method for processing form markings |
US20060242163A1 (en) * | 2005-04-22 | 2006-10-26 | Microsoft Corporation | Local thumbnail cache |
EP1920359A2 (en) * | 2005-09-01 | 2008-05-14 | Astragroup AS | Post-recording data analysis and retrieval |
KR100727974B1 (en) | 2005-09-10 | 2007-06-14 | 삼성전자주식회사 | Method and apparatus for generating thumbnails from digital images |
US20070076971A1 (en) | 2005-09-30 | 2007-04-05 | Nokia Corporation | Compression of images for computer graphics |
US7742636B2 (en) | 2006-01-26 | 2010-06-22 | Nethra Imaging Inc. | Method and apparatus for scaling down a bayer domain image |
WO2007095224A2 (en) * | 2006-02-10 | 2007-08-23 | Metacarta, Inc. | Systems and methods for spatial thumbnails and companion maps for media objects |
US8340179B2 (en) | 2006-03-21 | 2012-12-25 | Canon Kabushiki Kaisha | Methods and devices for coding and decoding moving images, a telecommunication system comprising such a device and a program implementing such a method |
JP4182990B2 (en) * | 2006-06-02 | 2008-11-19 | セイコーエプソン株式会社 | Printing device, method for determining whether image is blurred, and computer program |
JP4210954B2 (en) * | 2006-08-22 | 2009-01-21 | ソニー株式会社 | Image processing method, image processing method program, recording medium storing image processing method program, and image processing apparatus |
US8238678B2 (en) * | 2006-08-30 | 2012-08-07 | Siemens Medical Solutions Usa, Inc. | Providing representative image information |
US7573407B2 (en) | 2006-11-14 | 2009-08-11 | Qualcomm Incorporated | Memory efficient adaptive block coding |
US8090194B2 (en) | 2006-11-21 | 2012-01-03 | Mantis Vision Ltd. | 3D geometric modeling and motion capture using both single and dual imaging |
KR101437195B1 (en) | 2006-12-28 | 2014-09-03 | 톰슨 라이센싱 | Block artifact detection in coded pictures and images |
US8340196B2 (en) * | 2007-05-17 | 2012-12-25 | Lsi Corporation | Video motion menu generation in a low memory environment |
JP4551439B2 (en) * | 2007-12-17 | 2010-09-29 | 株式会社沖データ | Image processing device |
US8243329B2 (en) * | 2007-12-21 | 2012-08-14 | Seiko Epson Corporation | Printing control device, print data generation device, printing system and printing control program |
US8127058B1 (en) | 2008-07-29 | 2012-02-28 | Marvell International Ltd. | System and method of video decoding using hybrid buffer |
KR20100021168A (en) * | 2008-08-14 | 2010-02-24 | 삼성전자주식회사 | Apparatus and method for decoding image and image data processing unit and method using the same |
US8581937B2 (en) * | 2008-10-14 | 2013-11-12 | Adobe Systems Incorporated | Seam-based reduction and expansion of images using partial solution matrix dependent on dynamic programming access pattern |
KR101330771B1 (en) * | 2008-11-13 | 2013-11-19 | 삼성전자주식회사 | Sound zooming apparatus and method coupled with image zooming control |
US20100281224A1 (en) * | 2009-05-01 | 2010-11-04 | International Buisness Machines Corporation | Prefetching content from incoming messages |
WO2011002914A1 (en) | 2009-06-30 | 2011-01-06 | Massachusetts Institute Of Technology | System and method for providing high throughput entropy coding using syntax element partitioning |
KR101396409B1 (en) * | 2009-10-08 | 2014-05-19 | 삼성전자주식회사 | Moving-image photographing apparatus and method thereof |
US8340411B2 (en) * | 2010-03-05 | 2012-12-25 | Xerox Corporation | Smart image resizing with color-based entropy and gradient operators |
US8913666B2 (en) | 2010-10-01 | 2014-12-16 | Qualcomm Incorporated | Entropy coding coefficients using a joint context model |
US20120163448A1 (en) | 2010-12-22 | 2012-06-28 | Qualcomm Incorporated | Coding the position of a last significant coefficient of a video block in video coding |
US20120163456A1 (en) | 2010-12-22 | 2012-06-28 | Qualcomm Incorporated | Using a most probable scanning order to efficiently code scanning order information for a video block in video coding |
US8755620B2 (en) | 2011-01-12 | 2014-06-17 | Panasonic Corporation | Image coding method, image decoding method, image coding apparatus, image decoding apparatus, and image coding and decoding apparatus for performing arithmetic coding and/or arithmetic decoding |
TWI565304B (en) | 2011-06-24 | 2017-01-01 | 太陽專利信託 | Image coding method, image decoding method, image coding device, image decoding device, image coding and decoding device |
JP5385953B2 (en) * | 2011-08-05 | 2014-01-08 | 株式会社ソニー・コンピュータエンタテインメント | Image processing device |
JP5284451B2 (en) * | 2011-11-30 | 2013-09-11 | 株式会社東芝 | Electronic device and audio output method |
GB2498550B (en) | 2012-01-19 | 2016-02-24 | Canon Kk | Method and device for processing components of an image for encoding or decoding |
US20140270336A1 (en) * | 2013-03-15 | 2014-09-18 | Morphotrust Usa, Inc. | System and Method for Transaction Authentication |
US20140348240A1 (en) | 2013-05-22 | 2014-11-27 | Qualcomm Incorporated | Video coding using sample prediction among color components |
-
2009
- 2009-04-30 US US12/433,276 patent/US9076239B2/en not_active Expired - Fee Related
-
2013
- 2013-02-05 US US13/759,991 patent/US9105111B2/en not_active Expired - Fee Related
- 2013-02-06 US US13/761,085 patent/US9652818B2/en active Active
Patent Citations (64)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5761655A (en) * | 1990-06-06 | 1998-06-02 | Alphatronix, Inc. | Image file storage and retrieval system |
US6002794A (en) * | 1996-04-08 | 1999-12-14 | The Trustees Of Columbia University The City Of New York | Encoding and decoding of color digital image using wavelet and fractal encoding |
US6067068A (en) * | 1996-04-16 | 2000-05-23 | Canon Business Machines, Inc. | Scrollable display window |
US20030080977A1 (en) * | 1997-01-09 | 2003-05-01 | Canon Kabushiki Kaisha | Method and apparatus for compressing and scaling thumbnails |
US20020000998A1 (en) * | 1997-01-09 | 2002-01-03 | Paul Q. Scott | Thumbnail manipulation using fast and aspect ratio zooming, compressing and scaling |
US20030133007A1 (en) * | 1997-10-21 | 2003-07-17 | Katsumi Iijima | Image pickup apparatus |
US6670934B1 (en) * | 1999-02-03 | 2003-12-30 | William H. Gates, III | Method and system for distributing art |
US6418489B1 (en) * | 1999-10-25 | 2002-07-09 | Motorola, Inc. | Direct memory access controller and method therefor |
US20010037433A1 (en) * | 2000-05-15 | 2001-11-01 | Superspeed.Com, Inc. | System and method for high-speed substitute cache |
US20020103970A1 (en) * | 2000-08-15 | 2002-08-01 | Gut Ron Abraham | Cache system and method for generating uncached objects from cached and stored object components |
US7006099B2 (en) * | 2000-08-15 | 2006-02-28 | Aware, Inc. | Cache system and method for generating uncached objects from cached and stored object components |
US7287088B1 (en) * | 2000-10-06 | 2007-10-23 | Fotomedia Technologies, Llc | Transmission bandwidth and memory requirements reduction in a portable image capture device by eliminating duplicate image transmissions |
US20110229057A1 (en) * | 2000-12-01 | 2011-09-22 | Nikon Corporation | Image data processing device |
US6879981B2 (en) * | 2001-01-16 | 2005-04-12 | Corigin Ltd. | Sharing live data with a non cooperative DBMS |
US20030206661A1 (en) * | 2001-02-15 | 2003-11-06 | Schwartz Edward L. | Method and apparatus for clipping coefficient values after application of each wavelet transform |
US20040120585A1 (en) * | 2001-02-15 | 2004-06-24 | Schwartz Edward L. | Method and apparatus for sending additional sideband information in a codestream |
US20020172225A1 (en) * | 2001-05-21 | 2002-11-21 | Oon-Sim Ang | Clock signal decoupling for synchronous operation |
US20040205629A1 (en) * | 2001-08-08 | 2004-10-14 | Rosenholtz Ruth E. | Methods and systems for generating enhanced thumbnails usable for document navigation |
US20040205627A1 (en) * | 2001-08-08 | 2004-10-14 | Rosenholtz Ruth E. | Methods and systems for generating enhanced thumbnails |
US20030074525A1 (en) * | 2001-10-17 | 2003-04-17 | Fujitsu Limited | Cache control program and computer for performing cache processes |
US8046674B2 (en) * | 2001-10-31 | 2011-10-25 | Hewlett-Packard Development Company, L.P. | Internet browsing system |
US20030188121A1 (en) * | 2002-03-27 | 2003-10-02 | Sumit Roy | Efficiency in a memory management system |
US20040001631A1 (en) * | 2002-06-28 | 2004-01-01 | Microsoft Corporation | Generation of metadata for acquired images |
US7190806B2 (en) * | 2002-08-30 | 2007-03-13 | Hewlett-Packard Development Company, L.P. | System and method for data encryption/decryption |
US20040165789A1 (en) * | 2002-12-13 | 2004-08-26 | Yasuhiro Ii | Method of displaying a thumbnail image, server computer, and client computer |
US20040236897A1 (en) * | 2003-05-19 | 2004-11-25 | Chi-Chih Cheng | System and method for optimized access to memory devices requiring block writing |
US20080229237A1 (en) * | 2003-06-19 | 2008-09-18 | International Business Machines Corporation | System and computer-readable medium for ordering on-screen windows for display field of the invention |
US7426734B2 (en) * | 2003-10-24 | 2008-09-16 | Microsoft Corporation | Facilitating presentation functionality through a programming interface media namespace |
US20050259163A1 (en) * | 2004-05-18 | 2005-11-24 | Canon Kabushiki Kaisha | Information recording apparatus and control method thereof |
US8577157B2 (en) * | 2004-07-08 | 2013-11-05 | Canon Kabushiki Kaisha | Conditional replenishment for motion JPEG2000 |
US20060107289A1 (en) * | 2004-07-28 | 2006-05-18 | Microsoft Corporation | Thumbnail generation and presentation for recorded TV programs |
US20070081744A1 (en) * | 2005-05-09 | 2007-04-12 | Gokturk Salih B | System and method for use of images with recognition analysis |
US20100082774A1 (en) * | 2005-09-09 | 2010-04-01 | Pitts William M | Distributed File System Consistency Mechanism Extension for Enabling Internet Video Broadcasting |
US20130326572A1 (en) * | 2005-09-09 | 2013-12-05 | William M. Pitts | Distributed file system consistency mechanism extension for enabling internet video broadcasting |
US7774541B2 (en) * | 2005-12-27 | 2010-08-10 | Samsung Electronics Co., Ltd. | Storage apparatus using non-volatile memory as cache and method of managing the same |
US20070177822A1 (en) * | 2006-01-30 | 2007-08-02 | Brother Kogyo Kabushiki Kaisha | Removable medium device, medium for controlling removable medium device, and medium for controlling network device |
US20070237414A1 (en) * | 2006-02-23 | 2007-10-11 | Nam-Ik Cho | Method and apparatus for resizing images using discrete cosine transform |
US20070273702A1 (en) * | 2006-05-24 | 2007-11-29 | Nec Display Solutions, Ltd. | Image displaying device having image cache memory |
US20080005128A1 (en) * | 2006-06-30 | 2008-01-03 | Samsung Electronics., Ltd. | Method and system for addition of video thumbnail |
US20080209154A1 (en) * | 2007-02-28 | 2008-08-28 | Schneider James P | Page oriented memory management |
US7710434B2 (en) * | 2007-05-30 | 2010-05-04 | Microsoft Corporation | Rotation and scaling optimization for mobile devices |
US20080297532A1 (en) * | 2007-05-30 | 2008-12-04 | Microsoft Corporation | Rotation and scaling optimization for mobile devices |
US20100111429A1 (en) * | 2007-12-07 | 2010-05-06 | Wang Qihong | Image processing apparatus, moving image reproducing apparatus, and processing method and program therefor |
US20100049754A1 (en) * | 2008-08-21 | 2010-02-25 | Hitachi, Ltd. | Storage system and data management method |
US20100146016A1 (en) * | 2008-10-31 | 2010-06-10 | Nokia Corporation | Method and apparatus for file association |
US20100199024A1 (en) * | 2009-02-03 | 2010-08-05 | Samsung Electronics Co., Ltd. | Method and apparatus for managing data of flash memory via address mapping |
US20100278443A1 (en) * | 2009-04-30 | 2010-11-04 | Stmicroelectronics S.R.L. | Method and systems for thumbnail generation, and corresponding computer program product |
US8365081B1 (en) * | 2009-05-28 | 2013-01-29 | Amazon Technologies, Inc. | Embedding metadata within content |
US20110182502A1 (en) * | 2010-01-22 | 2011-07-28 | Corel Corporation | Method of Content Aware Image Resizing |
US8793290B1 (en) * | 2010-02-24 | 2014-07-29 | Toshiba Corporation | Metadata management for pools of storage disks |
US8793684B2 (en) * | 2011-03-16 | 2014-07-29 | International Business Machines Corporation | Optimized deployment and replication of virtual machines |
US8812450B1 (en) * | 2011-04-29 | 2014-08-19 | Netapp, Inc. | Systems and methods for instantaneous cloning |
US20130067138A1 (en) * | 2011-09-09 | 2013-03-14 | Ocz Technology Group Inc. | Non-volatile memory-based mass storage devices and methods for writing data thereto |
US20140369614A1 (en) * | 2011-12-20 | 2014-12-18 | Imagination Technologies, Ltd. | Method and apparatus for compressing and decompressing data |
US20140053206A1 (en) * | 2012-08-17 | 2014-02-20 | Flextronics Ap, Llc | Thumbnail Cache |
US20140064635A1 (en) * | 2012-09-01 | 2014-03-06 | Garrett M Johnson | Grain Effect |
US9479805B2 (en) * | 2013-02-15 | 2016-10-25 | Cox Communications, Inc. | Entitlement validation and quality control of content in a cloud-enabled network-based digital video recorder |
US9009763B2 (en) * | 2013-02-15 | 2015-04-14 | Cox Communications, Inc. | Content management in a cloud-enabled network-based digital video recorder |
US9124911B2 (en) * | 2013-02-15 | 2015-09-01 | Cox Communications, Inc. | Storage optimization in a cloud-enabled network-based digital video recorder |
US9226007B2 (en) * | 2013-02-15 | 2015-12-29 | Cox Communications, Inc. | Cloud-enabled network-based digital video recorder |
US9450934B2 (en) * | 2013-03-15 | 2016-09-20 | Cox Communications, Inc. | Managed access to content and services |
US8769031B1 (en) * | 2013-04-15 | 2014-07-01 | Upfront Media Group, Inc. | System and method for implementing a subscription-based social media platform |
US20140359382A1 (en) * | 2013-06-03 | 2014-12-04 | Shin-Ho Choi | Memory controller and operating method providing replacement block for bad block |
US9369406B2 (en) * | 2014-07-03 | 2016-06-14 | Sas Institute Inc. | Resource server providing a rapidly changing resource |
Non-Patent Citations (1)
Title |
---|
Silberschatz et al. (2002); Operating System Concepts, Chapter 12: File System Implementation (2002) pages 1-24. * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9105111B2 (en) | 2009-04-30 | 2015-08-11 | Stmicroelectronics S.R.L. | Method and systems for thumbnail generation, and corresponding computer program product |
Also Published As
Publication number | Publication date |
---|---|
US20100278443A1 (en) | 2010-11-04 |
US9652818B2 (en) | 2017-05-16 |
US9076239B2 (en) | 2015-07-07 |
US20130148906A1 (en) | 2013-06-13 |
US9105111B2 (en) | 2015-08-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9652818B2 (en) | Method and systems for thumbnail generation, and corresponding computer program product | |
JP4172333B2 (en) | Image display processing method | |
EP2118847B1 (en) | Method for processing a digital image | |
JP4919743B2 (en) | Method and apparatus for generating thumbnails with digital images | |
JP6590925B2 (en) | How to create a video | |
CN103828339B (en) | Splicing for digital image search | |
US8218616B2 (en) | Method and system for addition of video thumbnail | |
EP0967788A2 (en) | Dynamic generation of multi-resolution and tile-based images from flat compressed images | |
EP1641275B1 (en) | Interactive design process for creating stand-alone visual representations for media objects | |
US10593019B2 (en) | Method and apparatus for storing, processing and reconstructing full resolution image out of sub band encoded images | |
CN102196260A (en) | Partial expansion method of encoded images and image processing apparatus | |
WO2007058367A1 (en) | Album creating system, album creating method and album creating program | |
US20160358313A1 (en) | Systems and methods of automatic image sizing | |
TWI359390B (en) | ||
CN103886624A (en) | JPEG image thumbnail extracting method | |
JP4030014B2 (en) | Image display device and program thereof | |
CN104462159A (en) | Image conversion method and system based on document page content | |
JP4779524B2 (en) | Image processing apparatus and method, and program | |
CN104978756B (en) | A kind of seamless Zoom method and device of the page of embedded interactive assemblies | |
JP4446447B2 (en) | Image forming apparatus | |
JP6142549B2 (en) | Electronic document image compression device | |
CN111722771B (en) | Image association display method and device and computer readable medium | |
KR20040054115A (en) | Thumbnail image generation and browsing method for mobile communication device | |
JPH11284840A (en) | Image forming device | |
JP6008770B2 (en) | Image forming apparatus |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 4 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |