US20030091229A1 - Color image display accuracy using comparison of complex shapes to reference background - Google Patents
Color image display accuracy using comparison of complex shapes to reference background Download PDFInfo
- Publication number
- US20030091229A1 US20030091229A1 US09/778,484 US77848401A US2003091229A1 US 20030091229 A1 US20030091229 A1 US 20030091229A1 US 77848401 A US77848401 A US 77848401A US 2003091229 A1 US2003091229 A1 US 2003091229A1
- Authority
- US
- United States
- Prior art keywords
- color
- client
- server
- display device
- color image
- 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.)
- Abandoned
Links
- 238000000034 method Methods 0.000 claims abstract description 134
- 230000008569 process Effects 0.000 claims abstract description 107
- 230000004044 response Effects 0.000 claims abstract description 28
- 235000014510 cooky Nutrition 0.000 claims description 159
- 238000012937 correction Methods 0.000 claims description 66
- 238000012512 characterization method Methods 0.000 abstract description 14
- 230000002452 interceptive effect Effects 0.000 abstract description 5
- 238000012546 transfer Methods 0.000 description 19
- 238000010586 diagram Methods 0.000 description 18
- 238000013459 approach Methods 0.000 description 16
- 241001637516 Polygonia c-album Species 0.000 description 10
- 230000000694 effects Effects 0.000 description 8
- 230000003993 interaction Effects 0.000 description 8
- 239000000203 mixture Substances 0.000 description 8
- 230000004048 modification Effects 0.000 description 8
- 238000012986 modification Methods 0.000 description 8
- 230000007423 decrease Effects 0.000 description 7
- 239000011159 matrix material Substances 0.000 description 6
- 230000008901 benefit Effects 0.000 description 5
- OAICVXFJPJFONN-UHFFFAOYSA-N Phosphorus Chemical compound [P] OAICVXFJPJFONN-UHFFFAOYSA-N 0.000 description 4
- 238000003909 pattern recognition Methods 0.000 description 4
- 238000013515 script Methods 0.000 description 4
- 230000035945 sensitivity Effects 0.000 description 4
- 230000005540 biological transmission Effects 0.000 description 3
- 230000008859 change Effects 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 230000000977 initiatory effect Effects 0.000 description 3
- 238000007726 management method Methods 0.000 description 3
- 238000005259 measurement Methods 0.000 description 3
- 230000001174 ascending effect Effects 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 2
- 239000003086 colorant Substances 0.000 description 2
- 238000004891 communication Methods 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000014509 gene expression Effects 0.000 description 2
- 230000006872 improvement Effects 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 238000009877 rendering Methods 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 230000003466 anti-cipated effect Effects 0.000 description 1
- 230000004888 barrier function Effects 0.000 description 1
- 238000004737 colorimetric analysis Methods 0.000 description 1
- 239000012141 concentrate Substances 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000002708 enhancing effect Effects 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 238000003702 image correction Methods 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 238000009434 installation Methods 0.000 description 1
- 238000012423 maintenance Methods 0.000 description 1
- 230000007935 neutral effect Effects 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 238000012545 processing Methods 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 230000009466 transformation Effects 0.000 description 1
- 230000007704 transition Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G5/00—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators
- G09G5/02—Control arrangements or circuits for visual indicators common to cathode-ray tube indicators and other visual indicators characterised by the way in which colour is displayed
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N9/00—Details of colour television systems
- H04N9/64—Circuits for processing colour signals
- H04N9/68—Circuits for processing colour signals for controlling the amplitude of colour signals, e.g. automatic chroma control circuits
- H04N9/69—Circuits for processing colour signals for controlling the amplitude of colour signals, e.g. automatic chroma control circuits for modifying the colour signals by gamma correction
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N9/00—Details of colour television systems
- H04N9/64—Circuits for processing colour signals
- H04N9/73—Colour balance circuits, e.g. white balance circuits or colour temperature control
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2320/00—Control of display operating conditions
- G09G2320/06—Adjustment of display parameters
- G09G2320/0606—Manual adjustment
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2320/00—Control of display operating conditions
- G09G2320/06—Adjustment of display parameters
- G09G2320/0626—Adjustment of display parameters for control of overall brightness
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2320/00—Control of display operating conditions
- G09G2320/06—Adjustment of display parameters
- G09G2320/066—Adjustment of display parameters for control of contrast
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2320/00—Control of display operating conditions
- G09G2320/06—Adjustment of display parameters
- G09G2320/0666—Adjustment of display parameters for control of colour parameters, e.g. colour temperature
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09G—ARRANGEMENTS OR CIRCUITS FOR CONTROL OF INDICATING DEVICES USING STATIC MEANS TO PRESENT VARIABLE INFORMATION
- G09G2320/00—Control of display operating conditions
- G09G2320/06—Adjustment of display parameters
- G09G2320/0673—Adjustment of display parameters for control of gamma adjustment, e.g. selecting another gamma curve
Definitions
- the invention relates to color imaging and, more particularly, to presentation of color images on display devices.
- the product information may include a large number of images.
- the images enable web customers situated at client devices to view products before submitting an online purchase order. For some items, the user is permitted to click on a “thumbnail” image to view the item in a higher resolution format. For many retailers, however, the quality of the images can be a significant concern. Color accuracy, in particular, can be very important for retailers of products for which color matters.
- CTR cathode ray tube
- video card driver software
- operating system together determine how RGB pixel values will be rendered and displayed, and vary significantly from system to system.
- the invention relates to improvement of color image display accuracy in a computer network having display devices with different color output characteristics.
- the invention in one embodiment, makes use of gray elements in the form of complex, non-rectangular shapes such as numerals, letters, and the like to aid in a blackpoint estimate for characterization of each display device.
- rows or columns of non-rectangular shapes with varying gray values can be displayed against a black background that serves as a reference background.
- the blackpoint can be estimated by selection of one of the shapes, rows, or columns that appears to most closely match the background.
- the use of complex, non-rectangular shapes to determine blackpoint can help resolve minor differences in R, G, and B that can cause poor gray balance.
- three separate blackpoints can be estimated, one for each of the color channels of the display device, e.g., red, green, and blue (R, G, and B).
- R, G, and B red, green, and blue
- Estimation of multiple, channel-specific blackpoints is based on the realization that some display devices, such as CRT monitors, exhibit very different blackpoints for different color channels, and can be difficult to characterize using only a single RGB blackpoint estimate.
- estimating the blackpoint for each color channel (R, G, B) individually a more accurate characterization of the overall calorimetric response of the display device can be obtained.
- a more accurate calorimetric characterization which may result from the use of complex shapes in the blackpoint estimate, enables greater accuracy in a process for modification of color images that are delivered to and displayed on a particular display device.
- the invention can provide improved color image display accuracy. This can be achieved, for example, by obtaining the multi-channel blackpoint estimate and other information characterizing the color response of a display device associated with a client device residing on a computer network.
- the information can be used advantageously to modify color images delivered to the client over a computer network such as the World Wide Web.
- the invention in various embodiments, may be applied to provide color imagery modifications that compensate for the color response of the individual display device associated with the client.
- the display device may take the form of a cathode ray tube monitor, flat panel display, or similar color image display device.
- the multi-channel blackpoint estimate and additional information can be obtained, for example, by guiding the client through a color profiling process that profiles the color response of the display device.
- Guidance may take the form of a series of instructional web pages that are delivered to the client.
- the web pages can be made interactive to enable collection of color characterization data from the client.
- the color characterization data can be used to estimate a variety of information concerning display device characteristics such as the multi-channel blackpoint estimate, gamma, gray balance, and the like.
- a color profile can be created for the client's display device, and thereafter used for modification of color images delivered to the client.
- the color profile can be incorporated in information that is transmitted by the client to an image server for modification of color images to be delivered to the client.
- the information transmitted by the client can be embodied in a web cookie or other content container.
- a very accurate value for average gamma of RGB can be determined using a series of cascading steps.
- a gray patch selected for the coarse gamma measurement is used as the central patch for a range of gray patches used to measure a more finely tuned gamma.
- the term “gray,” as used herein, generally refers to a color formed by combinations of two or more color channels of various gray levels, in contrast to colors formed by single color channels.
- the fine gamma then can be used to form the central gray patch for gray balance determination.
- the user can complete the color profiling process in as few as four clicks, while gray balance determinations can be completed in a single click.
- a cookie can provide a persistent representation of the color response characteristics of the client's display device. Each time the client accesses a web server and color images are identified in web page content, the cookie can be sent to the appropriate image server to improve the accuracy of the color image displayed on the client's display device.
- the cookie may contain a computed color profile for a display device or parameters useful in computing such a color profile and thereby rendering color modifications, or “corrections,” to images provided to a client.
- the images viewed by the client appear as intended.
- the system and method are capable of providing accurate characterization of a display device, while affording reliability and ease of use for the user.
- the color of an item of interest more closely matches the actual color.
- items ordered by online customers are less likely to be returned based on color mismatch.
- Online retailers suffer from less returns, and online customers can shop with greater confidence that the items they order will arrive in the expected color.
- the invention provides a method comprising displaying gray elements against a background, wherein each of the gray elements has a different gray value and a non-rectangular shape, and estimating a blackpoint for a display device based on one of the gray elements selected by the user that appears to most closely match the background.
- the invention provides a system comprising a web server residing on a computer network, the web server transmitting web pages to remote clients residing on the computer network, a color image server residing on the computer network, the color image server transmitting color images referenced by the web pages to the clients for display on display devices associated with the clients, a color profile server residing on the computer network, the color profile server guiding the clients through a color profiling process to obtain information characterizing the color responses of the display devices associated with the clients, wherein the information includes a blackpoint estimate for the color channels of the display devices, and the color profiling process includes displaying gray elements against a black background, wherein each of the gray elements has a different gray value and a non-rectangular shape, selecting one of the gray elements that appears to most closely match the black background, and estimating the blackpoint for a display device based on the selected gray element, and one or more color correction modules that modify the color images transmitted by the color image server based on the information to improve the accuracy of the color images when displayed
- the invention provides a computer readable medium containing program code that causes a programmable processor to display gray elements against a background, wherein each of the gray elements has a different gray value and a non-rectangular shape, and estimate a blackpoint for a display device based on one of the gray elements selected by the user that appears to most closely match the background.
- FIG. 1 is a block diagram of a system for improving color image display accuracy in a computer network
- FIG. 2 is a block diagram of a web-based environment incorporating a system as shown in FIG. 1;
- FIG. 3 is a flow diagram illustrating a method for improving color image display accuracy in a computer network
- FIG. 4 is a flow diagram illustrating a color profiling process for a display device
- FIG. 5 is a flow diagram illustrating a multi-channel blackpoint determination in a color profiling process as shown in FIG. 4;
- FIG. 6 is a diagram of a web page for analog adjustment of a color display prior to blackpoint determination
- FIG. 7 is a diagram of a web page for determination of blackpoint for a particular color channel
- FIG. 8 is a flow diagram illustrating gamma and gray balance determination in a color profiling process as shown in FIG. 4;
- FIG. 9 illustrates a range of gray elements for use in determining a coarse gamma in a color profiling process as shown in FIG. 4;
- FIG. 10 illustrates a range of gray elements for use in determining a fine gamma in a color profiling process as shown in FIG. 4;
- FIG. 11 illustrates a range of gray elements for use in determining gray balance in a color profiling process as shown in FIG. 4;
- FIG. 12 illustrates an example of a color image transmitted to a client in a system as shown in FIGS. 1 and 2;
- FIG. 13 is block diagram illustrating transmission of color correction information in a system as shown in FIGS. 1 and 2;
- FIG. 14 is a block diagram illustrating an alternative architecture for a system for improving color image display accuracy in a computer network.
- FIG. 1 is a block diagram of a system 10 for improving color image display accuracy across a computer network.
- the computer network may take the form of a local area network, wide area network, or global computer network such as the World Wide Web.
- system 10 can be configured to obtain multi-channel blackpoint estimate that characterizes the colorimetric response of a display device associated with a client on the network.
- three separate blackpoints can be estimated, one for each of the color channels of the display device, e.g., red, green, and blue (R, G, and B).
- system 10 may include a web server 12 , a client 14 , a color image server 16 , and a color profile server 18 .
- Web server 12 provides client 14 with access to web pages incorporating graphic content such as color images. Some of the color images can be incorporated in the web pages stored at web server 12 while other color images are stored at color image server 16 .
- Web server 12 may store lower resolution color images, for example, as well as images that are less color-intensive. Higher resolution color images and more color-intensive images can be stored at color image server 16 .
- Web server 12 , client 14 , color image server 16 , and color profile server 18 each execute program code that is stored on computer-readable media residing locally with the respective device or executed remotely.
- the program code may reside in random access memory (RAM) that is accessed and executed by the client computer.
- the program code can be loaded into the memory from another memory device, such as a fixed hard drive or removable media device associated with client 14 .
- the program code can be initially carried on computer-readable media such as magnetic, optical, magneto-optic or other disk or tape media, or electronic media such as EEPROM.
- the program code can be loaded into the medium by transmission from a remote data archive, e.g., via a local area network, wide area network, or global network such as the Internet.
- a substantial portion of the code may be web page code that is transmitted to the respective device and executed by a server or browser application.
- Web page code e.g., Hypertext Markup Language (HTML), Extensible Markup Language (XML), or the like, generated by web server 12 may include image tags that point to specific color images stored at color image server 16 or elsewhere.
- HTML Hypertext Markup Language
- XML Extensible Markup Language
- Web page code generated by web server 12 may include image tags that point to specific color images stored at color image server 16 or elsewhere.
- color image server 16 is accessed to obtain any images tagged within the web page code.
- the content of a web page assembled for client 14 may include objects obtained from different resources within the network occupied by system 10 , such as web server 12 and color image server 16 .
- web server 12 and color image server 16 may be integrated with one another. In the example of FIG. 1, however, color image server 16 and web server 12 are separate entities.
- Web server 12 and color image server 16 each may interact with a database server and file server to obtain access to selected color images for delivery to client 14 .
- Client 14 may take the form of a variety of devices that permit a user to access resources on system 10 and display color images obtained from such resources.
- client 14 include desktop or portable computers operating in a Windows, Macintosh, Unix, or Linux environment, personal digital assistants (PDA's), based on the Palm, Windows CE, or similar operating system environments for small portable devices, Internet-equipped wireless telephones, interactive televisions with set-top boxes for Internet access, Internet kiosks available to the general public, and future Internet appliances that may emerge.
- PDA's personal digital assistants
- Each client 14 preferably executes a graphical viewing application such as a web browser to access resources residing on other resources, such as web server 12 and color image server 16 , attached to system 10 .
- a web browser application permits the user associated with client 14 to readily view web pages generated by web server 12 , and images served by color image server 16 .
- Other user interface applications may be useful in accessing web server 12 provided the information is presented in a user-interactive format.
- color image server 16 may be configured to deliver color corrected video imagery, in addition to static images.
- Video such as MPEG clips, streaming video, and the like may suffer from similar color accuracy issues if they are not compensated for the effects of the display device associated with an individual client 14 .
- some embodiments of the invention may be particularly useful for broadcast-like video content.
- client 14 includes a display device, such as a cathode ray tube or flat panel display, for display of color images obtained from web server 12 and color image server 16 .
- a display device such as a cathode ray tube or flat panel display
- Other types of displays as well as dynamic viewing media such as electronic paper are contemplated.
- Communication between web server 12 , client 14 , and color image server 16 may take place using conventional network protocols such as TCP/IP.
- TCP/IP network protocols
- client devices described above such as PDA's and wireless telephones, presently incorporate relatively low quality color displays, it is anticipated that such devices will benefit from higher quality color displays in the near future. Accordingly, system 10 will be readily applicable in enhancing the quality of color images displayed by PDA's, wireless telephones, and similar devices in the future.
- web server 12 may deliver web pages associated with an online retailer such as a clothing merchandiser.
- the web pages delivered by web server 12 may contain information concerning an array of items offered for sale by the retailer, as well as color images of the items for viewing by online customers. Some of the color images may constitute low resolution “thumbnail” images placed coincident with hypertext links to higher resolution images stored at color image server 16 .
- Client 14 executes the code delivered by web server 12 within a browser application to assemble a web page for display on a display device associated with the client.
- color image server 16 When a user associated with client 14 clicks on one of the thumbnail images with a pointing device, such as mouse, trackball, pen, or the like, client 14 accesses color image server 16 to obtain the higher resolution color image designated by an image tag embedded in the web page code. To permit display of the higher resolution color image with greater color accuracy, color image server 16 modifies the color image based on information obtained for client 14 . In particular, color image server 16 obtains information characterizing the color response of a display device associated with client 14 . The information can be uploaded to color image server 16 , e.g., in the form of a web cookie or other content container.
- the information can be transmitted, i.e., broadcasted, to a number of subscriber color image servers in system 10 , which are recognized by color profile server 18 .
- the information can be generated by guiding a user associated with client 14 through a color profiling process that profiles the color response of the display device.
- client 14 accesses a color image from color image server 16
- the user may be given a choice between viewing a version of the image with default color settings, or initiating the color profiling process to produce custom color settings for the user's display device and thereby improve the quality of the color image.
- the color image delivered by color image server 16 may be embedded in a web page with one or more hypertext links for initiation of the color profiling process through interaction with color profile server 18 .
- client 14 accesses color profile server 18 for delivery of a series of instructional web pages to the user.
- color profile server 18 guide the user through a number of steps designed to estimate the color response characteristics of the particular display device associated with client 14 .
- color profile server 18 delivers a web page with content that, when executed, generates a cookie containing the color profile information.
- the cookie then can be uploaded to color image server 16 for use in modifying the color image, and subsequently accessed color images, to produce higher quality color output on the display device associated with client 14 .
- Exemplary color profiling processes will be described in greater detail later in this detailed description.
- color profiling information may not require direct interaction by the user with a color image server 16 a - 16 n . Instead, the user may voluntarily visit a web site to perform color profiling.
- the web site may be provided by color profile server 18 or be within the same domain as the color profile server.
- users may profile the display devices associated with their individual clients 14 a - 14 n by executing software downloaded or physically delivered to them.
- display devices could be configured to produce a color profile when put in use, and transmit the color profile to subscriber color image servers, e.g., in a cookie.
- color profile server 18 receives essentially the same information for transfer to a number of individual color image servers for delivery of color corrected images to client 14 .
- FIG. 2 is a block diagram of a web-based environment 20 incorporating a system as shown in FIG. 1.
- Web-based environment 20 includes a number of subscribers 22 a , 22 b , and 22 c - 22 n , each of which may represent a commercial retailer with an online merchandising web site.
- subscribers 22 a - 22 n may include non-commercial entities as well, such as art museums and the like.
- a subscriber web server or “subscriber server” (SS 1 -SS N ) 12 a , 12 b , and 12 c - 12 n , delivers web pages with content describing the subscriber's merchandise
- a color image server (CIS 1 -CIS N ) 16 a , 16 b , and 16 c - 16 n delivers high quality color images that may be modified based on color profiles generated for individual clients 14 a , 14 b , and 14 c - 14 n .
- each of subscribers 22 a - 22 n posts its high quality color images to a respective color image server 16 a - 16 n , and maintains web pages that invoke the high quality images at a respective subscriber server 12 a - 12 n .
- One of the subscriber servers 12 a - 12 n and one of the color image servers 16 a - 16 n preferably are under the control of the respective subscriber.
- subscriber 22 a may be responsible for maintenance, administration, and content of subscriber server 12 a and color image server 16 a
- subscriber 22 b is responsible for subscriber server 12 b and color image server 16 b .
- subscribers 22 a - 22 n can readily update the contents of subscriber servers 12 a - 12 n and color image servers 16 a - 16 n themselves.
- subscribers 22 a - 22 n do not need to relinquish control of their image content to some third party in order to take advantage of the color image quality improvements contemplated in accordance with this embodiment of the invention. Instead, subscribers 22 a - 22 n make use of their own color image servers 16 a - 16 b and interaction with a color profile server 18 that guides the color profiling process for clients 14 a - 14 n . Nevertheless, in some embodiments, use of a central image server for all subscribers may be desirable.
- the commercial entities associated with subscriber servers 12 a - 12 b and color image servers 16 a - 16 n are “subscribers” in the sense that they all make use of color profiles generated by interaction with one or more common color profile servers 18 .
- a subscriber may be a retailer or collection of retailers with a web site that employs color correction as described herein, and makes use of color profile server 18 .
- Subscriber server 12 a - 12 n may be the subscriber's main web server.
- Color image server 16 a - 16 n can be a server that is co-located with or remotely located from a corresponding subscriber server 12 a - 12 n and contains the subscriber's high resolution or color-intensive color images and a color correction module for modifying the images and serving corrected images to clients 14 a - 14 n .
- Each color image server 16 a - 16 n may be within the domain of the respective subscriber server 12 a - 12 n , but this is not a requirement.
- clients 14 a - 14 n are potential customers of subscribers 22 a - 22 n who view the subscriber's web pages with their own browsers.
- Clients 14 a - 14 n access subscriber servers 12 a - 12 n , color image servers 16 a - 16 n , and color profile server 18 via World Wide Web 24 .
- the number of clients 14 a - 14 n and subscribers 22 a - 22 n shown in FIG. 1 is limited for ease of illustration, the actual number can be virtually unlimited subject to the bandwidth limitations of subscriber servers 12 a - 12 n , color image servers 16 a - 16 n , color profile servers 18 and web 24 .
- the color responses of individual display devices can be quite varied.
- color profiling process and color image modifications administered by color profile server 18 and color image servers 16 a - 16 n compensate for differences between the various client display devices and thereby increase the consistency of color output viewed by users situated across web 24 . If subscribers 22 a - 22 n are clothing retailers, for example, the color images viewed by clients 14 a - 14 n on disparate display devices can be made to more closely match the color of actual clothing items.
- FIG. 3 is a flow diagram illustrating a method for improving color image display accuracy in a computer network as shown in FIGS. 1 and 2.
- the client receives HTML code (or some other form of web page code) with embedded image tags identifying the locations of color images to be incorporated in the web page when it is presented on a display device, as indicated by reference numeral 40 .
- HTML code or some other form of web page code
- the image tags may point to locations resident at subscriber server 12 .
- client 14 executes the web page code to access and download color images from a designated color image server 16 , as indicated by reference numeral 42 in FIG. 3.
- the web page code executed by client 14 for access to color image server 16 queries whether a color profile cookie visible to the color image server has been generated for the particular client, as indicated by reference numeral 44 .
- a cookie is visible, for example, if it corresponds to the domain of the color image server. Management of cookies will be described later in this description.
- the color profile cookie contains information characterizing the color response of the display device associated with client 14 , and resides locally with the client. If a color profile cookie has been generated, client 14 uploads the cookie to color image server 16 , as indicated by reference numeral 46 .
- Color image server 48 retrieves the image requested by client 14 and modifies the image based on the contents of the cookie by applying a color correction, as indicated by reference numeral 48 .
- the color correction modifies the image to compensate for variations in the color response characteristics of the display device associated with client 14 .
- Color image server 16 then downloads the color corrected image to client 14 , as indicated by reference numeral 50 , and the process ends, as indicated by reference numeral 52 .
- client 14 receives a color corrected image that is customized for the client's display device to provide more accurate color output.
- client 14 downloads a default color image from color image server 16 , as indicated by reference numeral 54 , for presentation on the display device associated with the client.
- the image is a “default” image in the sense that it has not been color corrected or otherwise customized for the individual display devices associated with client 14 .
- the default image may exhibit significant color inaccuracy relative to the original color image.
- client 14 may present a color profiling option, as indicated by reference numeral 56 .
- client 14 may download with the image an indication of whether color profiling and correction has been applied to the image.
- client 14 may display that indication along with a hypertext icon that may invite the user to carry out color profiling.
- the user may click on the profiling icon with a pointing device to access the color profiling process.
- the profiling icon may indicate that profiling has already been performed and that the image has been color corrected, e.g., by displaying the icon in color. If profiling has not been performed previously, the icon may be displayed in black-and-white or some other indication can be provided. By clicking on the icon, the user can commence profiling, either in the first instance or as a profiling update.
- the user If the option is not selected, as determined at reference numeral 58 , the user simply views the default image and the process ends, as indicated by reference numeral 52 . If the option is selected, however, client 14 executes code that directs it to access color profile server 18 , e.g., via the hypertext link associated with the icon.
- Color profile server 18 guides the user associated with client 14 through a color profiling process, as indicated by reference numeral 60 . The color profiling process produces information characterizing the color response exhibited by the display device associated with the particular client 14 .
- client 14 Following completion of the color profiling process, client 14 generates a color profile cookie, as indicated by reference numeral 62 .
- the color profile cookie contains the color characterization information.
- Client 14 then uploads the color profile cookie to color image server, as indicated by reference numeral 46 , to obtain a color corrected image for improved color image accuracy. As will be explained, the cookie may need to be rewritten for the domain of the color image server 16 .
- the color profiling process optionally requires no plug-ins, Java scripts, or other significant client-side processes. Instead, interaction between subscriber server 12 , client 14 , color image server 16 , and color profile server 18 is driven by execution of the web page code delivered to client 14 . This approach yields significant convenience for the end user associated with client 14 .
- subscribers 22 a - 22 n are not required to retain color information for individual users. Rather, the information can be uploaded to color image server 16 , e.g., in the form of a cookie, whenever color images are requested by a client 14 .
- subscribers 22 a - 22 n can maintain their own color images at color image servers 16 a - 16 n , and provide color correction by incorporating a color correction module capable of handling the color profile cookies uploaded by individual clients 14 a - 14 n . Accordingly, there is no need for subscribers 22 a - 22 n to post their web pages or images to a central web repository.
- Color profile server 18 delivers a series of web pages to client 14 .
- Each of the web pages is designed to guide the user through a given step in the color profiling process.
- One web page may include instructions and image content designed to extract from the user an estimate of the blackpoint of the display device.
- the blackpoint estimate may be an estimate of multiple, channel-specific blackpoints.
- Other web pages may include instructions and content designed to extract coarse gamma, fine gamma, and gray balance information.
- each web page may include interactive media such as hypertext icons and the like that can be clicked upon by the user to transfer information from client 14 to color profile server 18 .
- color profile server 18 Upon collecting the necessary information, color profile server 18 creates the cookie and delivers it to client 14 for local storage and future use.
- two cookies can be provided to client 14 .
- a first cookie may correspond to a domain name associated with color profile server 18 , and be used for future interactive between the particular client 14 a - 14 n and the color profile server.
- the first cookie can be referred to as the “profiler cookie.”
- a second cookie may correspond to a domain name associated with the particular color image server 16 a - 16 n (corresponding to a particular subscriber such as a retailer) from which the color image is to be downloaded.
- the second cookie may correspond to the color image server 168 a - 168 n at which the color profiling process was initiated. In this manner, future images delivered by that color image server 16 a - 16 n will be modified based on the contents of the cookie associated with the pertinent domain.
- the second cookie can be referred to as the “subscriber cookie.”
- the profiler cookie can be used to produce additional subscriber cookies for use with color image servers 16 a - 16 n associated with other domains. Specifically, when a user situated at a client 14 a - 14 n accesses a color image server 16 a - 16 n from which the user has not previously downloaded color corrected images, the user can click on the color profiling option and be directed to color profile server 18 . Upon interaction with color profile server 18 , client 14 simply uploads the profiler cookie instead of repeating the color profiling process. Information concerning the domain associated with the new color image server 16 a - 16 n can be incorporated in the profiler cookie.
- color profile server 18 In response to receipt of the profiler cookie, color profile server 18 delivers a web page advising the user associated with client 14 a - 14 n of the intent to send the cookie contents to the domain indicated in the cookie, and may request user approval for, among other reasons, privacy concerns. Upon approval by the users, color profile server 18 transmits the cookie contents to the color image server 16 a - 16 n designated by the domain in the profiler cookie. In response, the color image server 16 a - 16 n creates a subscriber cookie for its own domain, and writes the cookie to client 14 a - 14 n for future use. Thereafter, client 14 uploads the appropriate subscriber cookie to the pertinent color image server 16 a - 16 n when requesting color corrected images for the pertinent subscriber 22 a - 22 n , and can bypass interaction with color profile server 18 .
- first and second cookies are driven in part by existing web design considerations.
- cookies stored on a client's browser typically are marked by the domain of the server that generates them, and are not generally visible to other domains.
- cookies created by color profile server 18 are not generally visible to color image servers 16 a - 16 n , and vice versa.
- cookie visibility can be further restricted by marking the cookie with a path within a server's domain. This sort of cookie will then not be visible on requests to pages outside the path, even if to the same domain.
- a browser routinely sends all visible cookies on each request to a server. This includes not only the initial request for an HTML page, but also the requests for images to be embedded in the page. Because an image can come from a different server than the HTML page, however, the cookies sent for the HTML page can differ from those sent for the image.
- color profile server 18 acts as an intermediary not only for administration of the color profiling process, but for generation of subscriber cookies.
- This intermediary function enables color correction of all subscriber images to be performed at color image servers 16 a - 16 n rather than at a centralized site.
- this intermediary function once a client has gone through the color profiling process, he generally will not have to repeat it to obtain color correction of images for additional subscribers.
- the user may voluntarily repeat the color profiling process when local driver software or hardware such as the display device or video card associated with a client 14 a - 14 n has changed. Indeed, to encourage updates from time to time in order to accommodate hardware changes, expiration dates can be applied to the profiler cookie and subscriber cookies.
- a subscriber server 12 a - 12 n serves the HTML for the subscriber's own web pages and handles most other requests for those pages, including serving of images that are not subject to color correction.
- Color image server 16 a - 16 n serves the images that are subject to color correction.
- color image server 16 a - 16 n receives the appropriate subscriber cookie, it performs color correction based on the cookie contents and serves the color corrected image to the appropriate client device 14 a - 14 n .
- Color image server 16 a - 16 n also may serve an icon near the correctable color images that indicates whether the color images have indeed been corrected. If color image server 16 a - 16 n finds no subscriber cookie, for example, it displays an icon suggesting that the user click the icon to initiate the color profiling process. Otherwise, the icon merely indicates that color correction is turned “on,” i.e., that color correction has been applied to the image.
- Color profile server 18 serves the pages for the color profiling process. If the color profiling process is invoked by clicking the icon displayed with a color image delivered by color image server 16 a - 16 n , the respective client 14 a - 14 n probably does not have a subscriber cookie for the pertinent subscriber 22 a - 22 n . In some cases, however, client 14 a - 14 n may be voluntarily repeating the color correction process to update the profile for new hardware or software. If a profiler cookie exists, then the process can be abbreviated by simply shipping the contents of the cookie to the appropriate subscriber domain for creation of the subscriber cookie.
- color profile server 18 If the profiler cookie does not exist, then the full color profiling process is served by color profile server 18 . Upon completion of the color profiling process, color profile server 18 generates the profiler cookie for client 14 a - 14 n , and passes the contents of the profiler cookie to the pertinent color image server 16 a - 16 n . Color image server 16 a - 16 n then generates the subscriber cookie based on the profiler cookie contents and invokes the original subscriber URL from which the color profiling process was invoked.
- color profile server 18 may be arranged to transmit the color correction information to all of the color image servers 16 a - 16 n associated with a recognized group of subscribers 22 a - 22 n . In this manner, the color profile information obtained by color profile server 18 as a result of the color profiling process can be “broadcasted” for storage by subscribers 22 a - 22 n .
- the advantage of this approach is that information transfer is seamless.
- each subscriber 22 a - 22 n stores the color correction information associated with the individual client 14 a - 14 n , e.g., with a client ID code.
- the client ID code is used to retrieve the appropriate color correction information and thereby serve a color corrected image.
- each subscriber 22 a - 22 n needs to maintain a database of color correction information for clients 14 a - 14 n requesting color corrected images from the participating subscribers, including clients who may never access a respective subscriber server 12 a - 12 n .
- an approach that makes use of cookies for transfer of color correction information may be more desirable for some subscribers 22 a - 22 n .
- broadcasting of color correction information remains a viable option that may be acceptable to some subscribers 22 a - 22 n , and highly convenient for end users.
- subscriber servers 12 a - 12 n preferably incorporate color profiling icons near the images.
- the URL's for the color profiling icons point to the pertinent color image server 16 a - 16 n , while the hypertext link associated with the icon points to color profile server 18 .
- the URL of the page viewed by the user is passed to color profile server 18 when the hypertext link associated with the icon is followed by a client 14 a - 14 n.
- This step of passing the URL can be accomplished either by including the URL as a parameter on the target URL, or by POSTing the information from a form that wraps the icon, i.e., with the URL stored in a hidden entry field. In the latter case, the icon serves as a button, which may require some minimal client-side scripting.
- the name of the subscriber 22 a - 22 n and the URL of a completion page to be served by the color image server 16 a - 16 n after the color profiling process is complete may be included in the request to color profile server 18 .
- Subscribers 22 a - 22 n can be provided with a server-side scripting function that inserts the icon code with the appropriate URLs.
- color profile server 18 serves a number of web pages that can be invoked by execution of a web page provided by subscriber server 12 a - 12 n .
- the “return URL” is passed forward to each page in the sequence.
- the return URL can be passed as a parameter in the target URL, or by using hidden fields in forms. In some cases, the return URL can be stored as a server variable.
- color profile server 18 handles two scenarios: (1) full color profiling when no profiler cookie exists, and (2) creation of a subscriber cookie when a profiler cookie already exists. In both scenarios, color profile server 18 transfers the contents of the existing or newly created profiling cookie to the pertinent subscriber 22 a - 22 n . In particular, color profile server 18 may present a button that requests permission of the user associated with client 14 a - 14 n to transfer the information.
- the URL for the button points to a page served by color image server 16 a - 16 n.
- the request sent to color image server 16 a - 16 n includes both the return URL and the color information written in the profiler cookie.
- the request preferably is a POST request from a form, rather than a GET request with all the information set forth in the URL due to length considerations.
- Color profile server 18 determines the URL of the destination page at subscriber 22 a - 22 n by reference to the return URL. Prior to transfer of the cookie contents, the user will want to know the destination. Accordingly, color profile server 18 displays the name of the particular subscriber 22 a - 22 n along with the button.
- the name of the subscriber is not easy to determine from the URL, it can be generated by cross-referencing the URL to a name in a database accessible by color profile server 18 , or by passing the name with the return URL in the original request from the page generated by subscriber server 12 a - 12 n.
- the pertinent color image server 16 a - 16 n serves a page indicating that the color profiling process is complete.
- the page may be invoked by the POST request containing the color correction information and the URL of the “return” page, as received from color profile server 18 .
- Color image server 16 a - 16 n writes the color correction information to the pertinent client 14 a - 14 n as a client cookie. From that point forward, the subscriber cookie is stored by the respective client 14 a - 14 n , and is sent to the color image server 16 a - 16 n associated with the pertinent subscriber 22 a - 22 n with any request for a color correctable image. In response, color image server 16 a - 16 n extracts the contents of the subscriber cookie, applies a color correction to the requested image based on the contents, and delivers the color-corrected image to the client 14 a - 14 n.
- color correction can be passed from color profile server 18 to the color image server 16 a - 16 n associated with the respective subscriber 22 a - 22 n via a direct request, rather than being embedded in a request generated when client 14 a - 14 n clicks on a button, anchor, or other input medium.
- This approach is direct in the sense that the user need not intervene by submitting approval for the transfer to color profile server 18 .
- the transfer of the content of the profile cookie to the appropriate color image server 16 a - 16 n can be made seamless. Indeed, in preferred embodiments, the user associated with client 14 a - 14 n does not even view pages sent by color profile server 18 for transfer of information following the initial profiling.
- the client 14 a - 14 n is assigned a client ID.
- the client ID can be stored in and received from a subscriber cookie on the browser associated with a client 14 a - 14 n .
- a client 14 a - 14 n that is new to the particular subscriber 22 a - 22 n i.e., a client that does not send a subscriber cookie to the particular color image server 16 a - 16 n , will be assigned a new client ID, which is sent as a cookie with the HTML in the response from the color image server.
- All URLs pointing to color profile server 18 then bear both the client ID and a subscriber ID as parameters, so that the color profile server can correlate requests for color correction information for the respective client 14 a - 14 n .
- the URL for the color profiling icon points to color profile server 18 if there is no subscriber cookie.
- the respective subscriber server 12 a - 12 n and corresponding color image server 16 a - 16 n occupy the same domain so that they can view the same cookies.
- a color profiling icon which appears adjacent a color correctable image, may be served from either color image server 16 a - 16 n or color profile server 18 in the direct transfer approach, depending on whether the color image server receives a subscriber cookie. If a subscriber cookie is present, the profiling icon is served by color image server 16 a - 16 n , and is formulated in appearance to indicate that color correction is active, e.g., with a text message to that effect. This will be the case for most images served by color image server 16 a - 16 n because only new clients 14 a - 14 n will not have the subscriber cookie.
- the icon is served by color profile server 18 .
- the web page served by color image server 16 a - 16 n has embedded in it an icon served by color profile server 18 .
- color profile server 18 serves an icon that indicates the client 14 a - 14 n has already been through the color profiling process. If not, the icon indicates that the color profiling process has not previously been completed by the respective client 14 a - 14 n . This may be represented by a colored icon to indicate that color profiling has been completed, and a black-and-white icon to indicate that it has not.
- the icon may indicate that the client 14 a - 14 n has been through the color profiling process, but that the color correction information has not yet been forwarded to the particular subscriber 22 a - 22 n , and that the image has not been color corrected.
- color profile server 18 also receives the ID for the client 14 a - 14 n and the subscriber 22 a - 22 n , which are included in the URL forwarded to color profile server 18 . If the profiler cookie is present, color profile server 18 immediately forwards the client ID and the contents of the profiler cookie to the pertinent color image server 16 a - 16 n in a special-purpose request.
- color image server 16 a - 16 n performs the color correction based on the information contained in the cookie. If the subscriber cookie is not present, color image server 16 a - 16 n waits a short time to receive color information for this client from color profile server 18 . If the information is forthcoming, color image server 16 a - 16 n applies the color correction and writes a subscriber cookie to the browser associated with the client 14 a - 14 n . Otherwise, color image server 16 a - 16 n serves an uncorrected image.
- color image server 16 a - 16 n it may be necessary for color image server 16 a - 16 n to keep track of color correction information forwarded by the color profile server 18 because such information may not be received synchronously with image requests from clients 14 a - 14 n . Accordingly, it may be necessary to incorporate a database application that can be shared by color image server 16 a - 16 n for temporary tracking of color correction information associated with individual clients 14 a - 14 n , and subscriber server 12 a - 12 n for tracking and generation of client ID information. Once the information has been written to a subscriber cookie, the ID and color correction information for the respective client 14 a - 14 n can be purged from the database.
- Management of ID's according to the direct transfer approach may take place as follows.
- the original color correction information generated by color profile server 18 can be stamped with a unique ID.
- the unique ID can be maintained in copies of the color correction information forwarded to subscribers 22 a - 22 n .
- This ID changes if the client 14 a - 14 n repeats the color profiling process, and can be referred to as the profiler ID.
- the profiler ID will remain unchanged until the next pass through the color profiling process, which may occur months later. In effect, the profiler ID corresponds to a particular color profiling sequence.
- the profiler ID is supplemented by the client ID and the subscriber ID.
- the client ID identifies a client for whom a subscriber 22 a - 22 n is requesting color information, and the subscriber ID identifies the particular subscriber.
- the client and subscriber IDs are passed via URL parameters to color profile server 18 whenever a color image server 16 a - 16 n has no color correction information for a particular client 14 a - 14 n .
- the subscriber ID is passed back with the color correction information from color profile server 18 to the color image server 16 a - 16 n when the color profile server determines the appropriate information for the client, based on the contents of a profiler cookie or the results of running the color profiling process. Once color image server 16 a - 16 n receives this information and writes it as a subscriber cookie to the client's browser, the subscriber ID is no longer needed.
- FIG. 4 is a flow diagram illustrating a color profiling process for a display device.
- a process as shown in FIG. 4 can be used to generate the contents of a profiler cookie as discussed above with reference to FIG. 3.
- the entire color profiling process can be completed by the user with as few as three “clicks” of a pointing device. If the user is required to click a continue button to proceed after selecting a patch, the process may take additional clicks. If the user is permitted to proceed automatically following selection of a patch, however, the entire process can be completed in three clicks. With optional analog adjustment, separate R,G, and B blackpoints, and fine gamma steps, to be described, the process may require up to six or seven clicks. Also, in many embodiments, the color profiling process requires no plug-ins or client side scripting when utilizing the method of selecting discrete elements, although such mechanisms can be provided in some embodiments such as in the use of slider adjustments.
- the color profiling process enables visual profiling of a display device by determining accurate values of blackpoint and gamma for the R,G, and B phosphors or photodiode elements.
- Gamma refers to a parameter y that indicates the rate of change in light intensity with change in digital device value.
- the term “blackpoint” refers to the lowest RGB values capable of representation on the display device. For color values below the blackpoint, there is no further decrease in light emitted by the display device. Blackpoint is sometimes alternatively referred to as black onset.
- three separate blackpoints are optionally determined, one for each of the R, G, and B color channels of the monitor. For use with more accurate monitors, a single dark gray RGB selection can be used to estimate a single average blackpoint value for R, G, and B.
- Color profile server 18 may administer a color profiling process as shown in FIG. 4 by serving a series of instructional web pages to client 14 a - 14 n .
- the color profiling process may involve determination of (1) blackpoint for each of the red, green, and blue (R, G, and B) color channels of the display device, (2) average gamma for R, G, and B, and (3) differences in gamma for R, G, and B. Due to the wide range of differences in display device properties, determination (2) above can be subdivided into determination of (2a) a coarse gamma estimate, and (2b) a fine gamma estimate. This process is described in greater detail below with reference to FIGS. 4 - 11 .
- the color profiling process first involves determination of an estimated blackpoint for each of the color channels of the color display device, e.g., R, G, B. After determining the blackpoints, which may be merely an estimate, the color profiling process involves determination of the gamma exhibited by the display device. In particular, the process may involve determination of a coarse gamma, as indicated by reference numeral 66 , followed by determination of a fine gamma, as indicated by reference numeral 68 . Determination of the fine gamma may rely in part on the coarse gamma. In other words, the coarse gamma can be used as an initial estimate and starting point for convergence toward a more finely tuned gamma.
- the process may involve determination of the gray balance exhibited by the display device, as indicated by reference numeral 70 of FIG. 4.
- Gray balance provides an indication of the amount of color shift of a neutral gray toward one or more of the color channels used by the display device, e.g., red, green, and blue.
- the gray balance determination may rely in part on the gamma determined previously in the color profiling process and, in a particular embodiment, the fine gamma.
- the color profiling process involves generation of a color profile, as indicated by reference numeral 72 .
- the color profile contains information that characterizes the color response of the display device based on the determinations indicated by reference numerals 64 , 66 , 68 , 70 , i.e., blackpoints, gamma, and gray balance.
- the color profile then can be loaded into a cookie, or other content container, and stored locally with client 14 for uploading to any of color image servers 16 a - 16 n when needed, as indicated by reference numeral 74 .
- the estimated blackpoint parameters define the dynamic range of the display device. Because the maximum RGB value always defines white, the blackpoint defines the black end point, and therefore defines the domain of values for each of the R, G, and B color channels that results in a continuous change from black to white. Again, blackpoint refers to the R, G, or B value below which there is no further decrease in light emitted by the display device. For an individual color channel, such as R, the blackpoint is the point at which further decreases in the R value produce no further decreases in R channel light emitted by the display device. If the blackpoint for a given color channel of a display device is high, values for that channel in darker regions will be mapped to the darkest shade and shadow detail will be lost if no image correction is performed. Accordingly, obtaining an accurate blackpoint estimate is important for the accuracy of images represented by the display device.
- the color profile may include a gamma parameter and a gray balance parameter.
- the parameters together define the colorimetric response of an individual display device to enable modification of color imagery for more accurate representation on the device.
- the gamma parameter most affects the overall appearance of the image. Gamma determines whether an image appears overall too light or dark, or with too much contrast or too little.
- the third parameter, R, G, B gamma difference or “gray balance,” is important because the human eye is very sensitive to gray balance.
- the gray balance parameter indicates the relative balance, or imbalance, between the different color channels of a display device when producing RGB color combinations.
- FIG. 5 is a flow diagram illustrating a color profiling process as shown in FIG. 4 in greater detail.
- color profile server 18 first may serve a web page for display device adjustment. The web page instructs the user to adjust the brightness and contrast of the display device. This step of display device adjustment is optional, but generally desirable in preparing the display device for blackpoint determination.
- color profile server 18 may serve a web page containing several rows of dark elements such as bars, patches, characters, letters, numerals, and the like.
- patches or bars it may be desirable to display elements with alternative shapes such as numerals.
- the patches or bars may be generally rectangular, more complex shapes can be used to aid the human eye in resolving differences.
- numerals, letters, and other complex shapes engage the pattern recognition capabilities of the human eye and can result in heightened sensitivity to gray scale differences.
- the complex shape presents a longer boundary relative to simple shapes, and promotes an increased perimeter for contrast.
- Elements with complex shapes may be used in the blackpoint, coarse gamma, and fine gamma determinations to characterize the monitor.
- the elements can be arranged in columns placed side-by-side across the web page.
- each row or column may contain, instead of several elements, only one or a small number of elements. A larger number of elements in each given row may aid the user in resolving differences between elements in adjacent rows.
- the web page may instruct the user to set the brightness and contrast of the display device to maximum, as indicated by reference numeral 78 .
- the rows (or columns) of elements may be arranged in a series.
- the elements in each row preferably exhibit the same darkness or lightness. However, the elements in each row in the series differ in relative darkness or lightness relative to the elements in other adjacent rows. For example, the darkest row of elements could be situated at the bottom, with rows containing elements with progressively lighter shades being situated above in ascending order.
- the web page instructs the user to reduce the brightness until the darkest row of elements is barely visible. At this point, the user may select “next” or some similar hypertext icon and proceed to the next step in the color profiling process, e.g., blackpoint determination for each of the red, blue, and green channels on an individual basis.
- FIG. 6 illustrates a web page 122 for use in display device adjustment in a color profiling process as shown in FIG. 5.
- Rows 124 of dark elements are displayed, with the elements each row having the same gray level value, but different gray level values from elements in adjacent rows.
- rows 124 of dark elements may be presented to the user with the following gray level values: 8, 16, 24, and 32.
- the rows of “zeros,” “ones,” “twos,” and “threes” may have gray levels of 8, 16, 24, and 32, respectively.
- the rows of dark gray elements are displayed, the user is instructed to set brightness and contrast of the display device to maximum, using the analog or digital controls provided with the display device.
- the user is then further instructed to reduce the brightness of the display device until the row with the darkest (lowest gray level value) elements is barely visible, and then click “next” upon completion.
- This optional step of display device adjustment serves to prepare the monitor for the blackpoint determination carried out with respect to each color channel, as described below.
- the blackpoint determination process for each color channel involves several rows (or columns) of dark elements for each color channel. Specifically, red channel, blue channel, and green channel web pages for channel-specific blackpoint determination can be served to the client in any order.
- the dark elements for a given color channel may be arranged in rows in ascending or descending order of relative lightness or darkness, as in web page 122 of FIG. 6, which is served for display device adjustment.
- the rows provide a sequence of gray level gradations.
- the bottom row for the red channel blackpoint determination web page may be a row of “zeros” having elements bearing the darkest shade (lowest gray value) of red among the elements shown on the web page.
- arrangement of the elements in rows or columns is for purposes of illustration. In some embodiments, display of a series of individual elements (rather than rows of elements) may suffice.
- the row of darkest elements that is barely visible to the user will depend on the blackpoint for the respective channel of the display device.
- the user may be unable to see elements with intensity levels of 8, 16, or higher.
- the user is instructed to select the row of elements that is barely visible on the display device. This step determines the blackpoint, i.e., the visible “cut-off” point at which further decreases at which further decreases in the color channel value produce no further decreases in light emitted by the display device for that color channel.
- the user could be prompted to make the least visible row of elements vanish for a given color channel and then click on the remaining barely visible bar. In either case, the blackpoint can be estimated.
- FIG. 7 illustrates a web page 128 for use in blackpoint determination in a color profiling process as shown in FIG. 5.
- Web page 128 may be substantially similar to web page 122 of FIG. 6.
- web page 128 may include rows 130 of shaded elements. Again, display of columns of elements or a series of elements may be sufficient for some applications.
- web page 128 instructs the user to select the row of elements that is barely visible on the display device.
- the rows 130 in web page 128 may be arranged as rows of “zeros,” “ones,” “twos,” and “threes” having, for example, intensity levels of 8, 16, 24, and 32, respectively.
- Web page 128 in FIG. 7 represents the web page for red channel blackpoint determination, and includes rows of red elements set against a black background.
- FIG. 5 further illustrates the process.
- FIG. 5 shows the display of rows of dark red elements or characters ( 82 ), and selection of the row that is barely visible ( 84 ), and further illustrates the computation of the estimated blackpoint for the red channel based on the selected row ( 86 ).
- a row of dark green characters is displayed ( 88 ), followed by selection of the row that is barely visible ( 90 ), and computation of an estimated blackpoint for the green channel based on the selected row ( 92 ).
- a row of dark blue characters is displayed ( 94 ), followed by selection of the row that is barely visible ( 96 ), and computation of an estimated blackpoint for the blue channel based on the selected row ( 98 ).
- client device 14 a - 14 n transmits the result to color profile server 18 .
- the results for all color channels can be transmitted at the same time following completion of the blackpoint determination for the last color channel.
- Color profile server 18 then may compute the estimated blackpoint for each channel, as indicated by reference numerals 86 , 92 , 98 , or simply store the parameters for later computation, e.g., by color imager server 16 .
- the variables dr, dg, and db are the digital input values normalized to 1.0.
- the parameters k o,r , k o,g , and k o,b are the blackpoints and the parameters ⁇ r , ⁇ g , and ⁇ b are the gammas for the red, green, blue channels.
- the values of parameters k o,r , k o,g , and k o,b are determined as follows: Assume that (regardless of the properties of a particular monitor) for the red channel there exists a minimal visible set of values for XYZ that can be detected by the human eye, designated as the vector (X t,r ,Y t,r ,Z t,r ). This vector will have a unique corresponding value for R in the expression above, designated as R t .
- R t ⁇ ⁇ [ ( d t , r - k o . r ) / ( 1.0 - k o . r ) ] ⁇ r ⁇ 0 , [ ( d t , r - k o . r ) / ( 1.0 - k o . r ) ] ⁇ 0 [ ( d t , r - k o . r ) / ( 1.0 - k o . r ) ] ⁇ 0 [ ( d t , r - k o . r ) / ( 1.0 - k o . r ) ] ⁇ 0 ⁇
- This device value d t,r is determined by the user during the color profiling procedure as described, i.e., by selecting the darkest barely visible row of elements in the blackpoint determination web page for red.
- FIG. 8 is a flow diagram illustrating gamma and gray balance determination in a color profiling process as shown in FIG. 5.
- coarse gamma one of the web pages served by color profile server 18 displays a range of green elements, e.g., patches, against a dithered green background, as indicated by reference numeral 100 .
- the coarse gamma determination web page can be served immediately and automatically following selection of a row of elements in the last blackpoint determination web page, or in response to selection of a “next” icon or similar device.
- the coarse gamma determination is limited to only the green color channel. Specifically, the coarse gamma determination is made using a series of green elements against a green dithered background. Green is the most dominant and intense phosphor among red, green, and blue, and is highest in contrast. Green also has the highest L*. Note also that green most closely matches the photopic V( ⁇ ) response of the eye. This approach to coarse gamma determination considers only the green color channel, and essentially ignores red and blue. In this manner, the coarse gamma measurement concentrates on the most dominant color channel and avoids errors that can arise to the red-blue imbalances that are highly prevalent in many display devices.
- the elements displayed for the coarse gamma determination may be green patches with different darkness or lightness values.
- a combined coarse gamma for all of the color channels may be determined as described in the above-referenced U.S. patent application Ser. No. 09/631,312.
- the coarse gamma determined in this step can be used as an estimate for the average gamma of R, G, and B via selection of a green patch from the set of green patches against the dithered green background.
- the dithered green background may be set at approximately 25% to 50%. Dithered backgrounds approaching approximately 33% may more closely match the actual midpoint of black to green transition for the display device, and may be preferred for typical display devices.
- the center patch in the range 132 of patches can be based on an average gamma of 2.0, since most monitors range from 1.6 to 2.5.
- the other green patches that surround the center patch may proceed in a sequence with relatively large steps, e.g., 8 gray levels apart from one another.
- Coarse gamma can be estimated using the equation:
- d .33,g is the gray level value (normalized to 1.0) of the selected patch that appears to most closely blend in with the background
- k o,g is the previously determined blackpoint
- G .33 is the relative intensity of the green channel (equal to 1 ⁇ 3)
- ⁇ g is the green gamma.
- the green level value of the selected patch simply is carried forward for use in the fine gamma process. In this case, the value can eventually be discarded.
- Fine gamma is a refined or “fine-tuned” estimate for the average gamma of R, G, and B.
- Fine gamma can be determined by selection of another green patch from a set of green patches presented against a dithered green background.
- the center patch may be identical to the green patch selected by the user for determination of coarse gamma.
- the coarse gamma step “informs” the fine gamma step.
- the selected coarse gamma patch may serve as a starting point for the fine gamma determination.
- the green patch selected in the coarse gamma determination can be used as the central patch for the fine gamma determination.
- a range of patches for determining fine gamma is illustrated in FIG. 10 and designated by reference numeral 134 .
- the patches in this range are in a sequence with smaller steps centered about the center green patch selected in the coarse gamma process.
- the patches may be set at 4 green levels apart, in contrast to the 8 green levels used as the difference for the coarse gamma determination.
- a narrower range is used to “fine-tune” the coarse gamma estimate, with the center of the range having been “learned” from the coarse gamma estimate.
- a web page served by color profile server 18 displays the selected green patch from the coarse gamma estimate among a narrower range of green patches. The user then is instructed to select the green patch that most closely blends with the same dithered green background as used for coarse gamma, as indicated by reference numeral 108 . Based on the selected patch, color profile server 18 computes a single fine RGB gamma, as indicated by reference numeral 110 . Thus, the fine gamma is the overall gamma estimated for the RGB channels.
- the RGB value of the selected patch can simply be stored for use by color image server 16 a - 16 b in computing fine gamma and rendering color corrections. In any event, a refined estimate for gamma can be computed according to the equation:
- d .33,g is the green level value (normalized to 1.0) of the selected patch that blends in with the background
- k o,g is the previously determined blackpoint
- G .33 is the relative intensity of the green channel (equal to 1 ⁇ 3)
- ⁇ g is the green gamma.
- color profile server 18 serves a web page that displays a plurality of RGB gray patches.
- the RGB gray patches can be generated with the same value of green selected in the previous fine gamma step in conjunction with values of red and blue that are substantially equal to or systematically shifted from the previously selected value of green.
- the RGB patches can be displayed against a gray background which is dithered in the same manner as the green dithered background of the previous step (fine gamma), as indicated by reference numeral 112 . Again, this step “learns” from the previous one, and forms part of a cascading series of color profiling steps (coarse gamma, fine gamma, and gray balance) that help narrow the search for the correct gamma.
- the user is then instructed to select the gray patch that appears to most closely blend with the dithered background. Based on the selected gray patch, individual RGB gammas are computed, as indicated by reference numeral 116 . Notably, the overall gray balance determination can be made with a single click of the user's pointing device.
- the green intensity value selected in the fine gamma process is used to generate the gray patches that exhibit +/ ⁇ (plus/minus) differences or “shifts” in red and blue about the value of the central gray patch derived from the gamma estimate.
- the value of green selected in the fine gamma process can be displayed in the center of the range in conjunction with substantially identical values of red and blue.
- the gammas for red and blue are then fine tuned by the gray balance determination, which helps identify red-blue imbalance in the display device.
- the green gamma is “locked in” in the gray balance step, while the red and blue imbalance is determined.
- every patch in the gray balance array carries the same green value, but is modulated by different gradations of red and blue.
- This step eliminates one axis of variation, green, but permits identification of any imbalance between red and green or blue and green. This limits the range of choices to a more finely-tuned area, and aids the user in making a more accurate selection.
- the range of patches for the gray balance determination may be a two-dimensional array of patches with red-blue-shifted patches arranged around a central gray patch formed according to the gamma estimate from the fine gamma process.
- the red channel could be used to determine the initial RGB gamma estimate, followed by a gray balance determination that resolves imbalance between green and red or blue and red.
- FIG. 11 illustrates an example of a two-dimensional range 136 of gray patches arranged in a five-by-five matrix for use in the gray balance determination.
- Each patch represents a shift away from the central gray patch along either the blue axis, the red axis, or a combination of both, but preferably does not represent any further green shift.
- the user selects the patch that appears to most closely blend with the dithered gray background, which may be a 33% dithered background.
- the central patch can optionally be highlighted to indicate it is the preferred default choice.
- the number of patches and the exact values of RGB for each patch can be quite flexible.
- all patches can be selected to have identical values of L* as indicated by the estimated profile for the display based on phosphors, average gamma, and blackpoint.
- Patches adjacent to the center may differ by all permutations of +/ ⁇ 3 ⁇ E for a* and for b* as estimated from a Matrix TRC (tone reproduction curve) profile constructed from the above parameters.
- Patches around the outer perimeter of the grid array may differ from the center by +/ ⁇ 6 ⁇ E in R and B.
- R and B may vary only by +/ ⁇ a fixed amount such as +/ ⁇ 5 gray levels and +/ ⁇ 10 gray levels.
- all patches are relatively small deviations from the central patch in all directions of color space of approximately constant L*. This test will help determine in a sensitive manner whether there exists a significant difference in the gammas of R, G, and B, and thereby expose significant gray imbalance between R and B.
- the two-dimensional format of the patches shown in FIG. 11 may aid the user's selection of the correct patch.
- the patch from the previous step in the color profiling process i.e., fine gamma
- Adjacent patches differ in gray level as the array extends outward such that the outer periphery of the array contains patches that are two gradations removed from the central patch.
- the array produces a visual “funnel” effect that, from experience, tends to direct the user toward the central patch as the starting point for matching with the background.
- the differences between patches in the two-dimensional array are more clear and dramatic than in a one-dimensional strip of patches. As the array extends outward, the shift becomes greater.
- the gradations are well pronounced and aid the user in picking the appropriate patch which, in many cases, will be the central patch selected in the previous step of the color profiling process.
- the process of selecting patches in the coarse gamma, fine gamma, and gray balance determination steps is advantageous because, in preferred embodiments, it requires no applications, applets, or other client-side scripts to be loaded at the client side. Rather, the user may simply select one of the patches displayed in a web page. In other embodiments, however, if applications, applets, or client-side scripts are used, it is conceivable that smooth slider bars, +/ ⁇ arrows, and the like could be used to adjust the color of a single patch in real-time for comparison to the dithered background. In this manner, the user has the ability to precisely match a single patch to the background, rather than select from a finite set of patches the one that most closely matches.
- the patch or element selected by the user may be a single adjustable patch in a condition in which the slider or other adjustment medium has adjusted its color to a level that is visually acceptable to the user, i.e., to a point at which the patch appears to match the dithered background.
- a color profile for the display device is generated, as indicated by reference numeral 118 .
- a color profiler cookie is created, as indicated by reference numeral 120 .
- Information representative of the color profile is added to the color profiler cookie for future use.
- the information can be used to create a subscriber cookie for future interaction between the particular client 14 a - 14 n and the particular subscriber 22 a - 22 n and color image server 16 a - 16 n .
- the color profile is especially useful for characterizing display devices in a network, it also may be useful in a non-networked application.
- the color profiling process described herein may find ready use in the calibration and characterization of an individual display device for correction of content generated or obtained locally with the device, rather than across a network.
- the client 14 a - 14 n there is no need for the client 14 a - 14 n to provide information regarding the configuration of its display device. Very satisfactory results can occur using an average set of phosphor values based on published standards such as sRGB, Apple Macintosh RGB, and the like. If desired, further steps can be added, particularly in order to address the issue of phosphor values and white point.
- the color profiling process simply results in generation of a cookie that serves as a container and vehicle for passing information characterizing the color response of the display device associated with client 14 a - 14 n to color image server 16 a - 16 n .
- the chromaticity information and white point can in some cases be obtained from the display utilizing communication protocols such as VESA and/or from the operating system of the computer.
- communication protocols such as VESA and/or from the operating system of the computer.
- each cookie should include the gamma values for R, G, and B. Each gamma value may be a value between 1.0 and about 3.0.
- the cookie may include the chromaticity values for black and white, e.g., expressed as a value between 0 and +1000.0.
- An exemplary cookie may have the following items packed into its value string, each demarcated by a separator:
- Cookie format version code a numeric code, e.g., 1 to 3 bytes, plus separator.
- Cookie installation date the usual cookie-style timestamp (milliseconds after midnight of Jan. 1, 1970, GMT), e.g., 12 to 13 bytes, plus separator.
- Display Device ID code an alphanumeric code, which may be roughly 10 bytes plus separator.
- Cookie Data Checksum a long integer: 4 bytes.
- the example cookie described above has about 68 bytes plus 10 separators.
- the separator character should be chosen so that the string does not have to be “escaped”; the caret (A) is frequently used this way.
- the typical size for the value string may be about 80 bytes.
- FIG. 12 is an example of a color image 184 transmitted to a client 14 a - 14 n in a system as shown in FIGS. 1 and 2.
- the image 184 may be presented on a screen 182 on a display device associated with a client 14 a - 14 n .
- a color image server 16 a - 16 n associated with a particular subscriber 22 a - 22 b such as “ABC Company,” delivers image 184 to the client 14 a - 14 n upon request.
- image 184 may be accompanied by a legend 186 that identifies the subscriber 22 a - 22 n and a particular item being displayed.
- an icon, button, or the like may accompany image 184 and indicate whether color correction has been applied by color image server 16 a - 16 n , as indicated by reference numeral 188 .
- color correction has not been applied, e.g., because a subscriber cookie has not yet been generated for the particular subscriber 22 a - 22 n .
- Another icon, button, or the like may be displayed to invite the user to profile its display device, as indicated by reference numeral 190 .
- Elements 188 and 190 could be integrated with one another, as discussed previously, and take on an appearance such as a particular color scheme that indicates whether color correction has been applied. In either case, element 190 provides a hypertext link to the URL associated with color profile server 18 . Thus, when the user clicks on element 190 , pages are requested from color profile server 18 for initiation of the color profiling process. If a profiler cookie already exists, however, it is sent by client 14 a - 14 n to color profile server 18 . In that case, there is no need to repeat the color profiling process. Instead, color profile server 18 creates a subscriber cookie for the pertinent subscriber 22 a - 22 n , and forwards it to the associated color image server 16 a - 16 n , either directly without user intervention or indirectly with user approval as previously described.
- FIG. 13 is block diagram illustrating transmission of color correction information in a system as shown in FIGS. 1 and 2.
- FIG. 13 illustrates a situation in which subscriber cookies have already been created for color image servers 194 , 198 associated with particular subscribers 22 a - 22 n accessed by an individual client 196 .
- client 196 upon accessing a web page from a subscriber server 12 a - 12 n , client 196 requests images from color image server 194 .
- client 196 requests images from color image server 198 .
- Color image server 194 incorporates both a color correction module 200 and an archive 202 of color images.
- color image server 198 includes a color correction module 204 and an archive of color images 206 .
- client 196 sends an image request to color image server 194 , it sends along a color profile cookie, i.e., a subscriber cookie, as indicated by line 208 .
- client 196 sends a subscriber cookie to color image server 198 when requesting an image.
- the subscriber cookie contains a color profile that provides color correction information for use by the respective color correction module 200 , 204 in modifying, i.e., color correcting, the color images served from image archives 202 , 206 , respectively.
- color images server 194 or 198 processes the accompanying subscriber cookie to extract the contents, and controls the color correction module 200 , 204 based on the extracted contents.
- client 196 receives color corrected images, as indicated by reference numerals 212 and 214 .
- the variables d r , d g , and d b are the digital input values normalized to 1.0.
- the parameters k o,r , k o,g , and k o,b are the blackpoints for the red, green, and blue channels, and the parameters ⁇ r , ⁇ g , and ⁇ b are the gammas for the red, green, blue channels.
- the gamma and blackpoint information contained in the subscriber cookie for a respective display device can be used in the above equations to produce, in effect, a destination device profile.
- the destination device profile with a source profile previously computed for the requested image, can be used to perform a transformation of the image data sufficient to produce calibrated output on the display device.
- This profile description can either be used in this format or converted to formats such as those specified by the ICC.
- This format is also known as the Matrix TRC format, and utilizes a generic lookup table for the expressions above for R, G, and B rather than an equation combined with a matrix similar to above.
- the above information e.g., gammas, blackpoints, and the like, can be stored in a cookie on a computer associated with a client 14 a - 14 n .
- the individual data which are the RGB values of the patches selected by the user can be stored in the cookie, which can permit improved profile technology to be employed at a later date utilizing the same input information.
- the existing subscriber server 12 a - 12 n is modified to replace existing image file references indicated in HTML pages with similar references to a pertinent color image server 16 a - 16 n equipped with a color correction module.
- an existing subscriber image file reference called:
- All images stored on the subscriber server 12 a - 12 n may have a corresponding copy file of the same name residing on the subscriber color image server 16 a - 16 n .
- the color image server 16 a - 16 n may access this database of image files to read, convert, and send images referenced by the HTML page sent to the client 14 a - 14 n .
- color image server 16 a - 16 n may use a very simple and quick technique for color management.
- all images on the color image server 16 a - 16 n preferably have a predetermined RGB color space.
- RGB color spaces are ColorMatch RGB, which has a color temperature for the “virtual display” of D 50 .
- Other color spaces such as Adobe RGB have an excellent gamut, but have a color temperature of D 65 .
- color image server 16 a - 16 n accesses the corresponding image and converts the RGB data in real time before sending the image to the client destination.
- the conversion can be performed according to the following calculation:
- R s ⁇ ⁇ [ ( d r , s - k o , r , s ) / ( 1.0 - k o , r , s ) ] ⁇ r , s ⁇ 0 , [ ( d r , s - k o , r , s ) / ( 1.0 - k o , r , s ) ] ⁇ 0 [ ( d r , s - k o , r , s ) / ( 1.0 - k o , r , s ) ] ⁇ 0 [ ( d r , s - k o , r , s )
- FIG. 14 is a block diagram illustrating an alternative architecture for a system 214 for improving color image display accuracy in a computer network.
- System 214 conforms substantially to the system shown in FIG. 2, except that all images for the subscribers are stored at a central color image server 16 .
- Color profiling server 18 may reside or be integrated with color image server 16 in the embodiment of FIG. 14. In this case, color profiling server 18 provides web pages for guidance of a color profiling process as described herein.
- Color image server 16 or color profile server 18 may include a database server for storage of individual color profiles associated with clients 14 a - 14 n .
- a client 14 a - 14 n When a client 14 a - 14 n requests an image tagged in the code sent by one of subscriber servers 12 a - 12 n , it is directed to the central color image server 16 .
- the color image server 16 may use a client ID sent from the client to retrieve the appropriate color profile and apply it to modify the requested color image using techniques as described herein for color correction. In this manner, color image server 16 provides color corrected images without the need for transfer of cookies and the like between clients 14 a - 14 n and the color image server.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Facsimile Image Signal Circuits (AREA)
- Image Processing (AREA)
- Color Image Communication Systems (AREA)
Abstract
Description
- This application claims priority from U.S. provisional application serial No. 60/193,725, filed Mar. 31, 2000, U.S. utility application Ser. No. 09/631,312, filed Aug. 3, 2000, and U.S. provisional application serial No. 60/246,890, filed Nov. 1, 2000, the entire content of each being incorporated herein by reference.
- The invention relates to color imaging and, more particularly, to presentation of color images on display devices.
- The growth of the Internet has created sizable opportunities for online retailers. Most major retailers of consumer products have established commercial sites on the World Wide Web. At the same time, the availability of web site presence has eliminated many of the marketing barriers previously experienced by smaller retailers. Virtually any retailer can now post product information for easy access by potential customers, and take orders for its products in an automated fashion.
- The product information may include a large number of images. The images enable web customers situated at client devices to view products before submitting an online purchase order. For some items, the user is permitted to click on a “thumbnail” image to view the item in a higher resolution format. For many retailers, however, the quality of the images can be a significant concern. Color accuracy, in particular, can be very important for retailers of products for which color matters.
- In the case of clothing retailers, for example, an image of a sweater should match its actual color as closely as possible. Unfortunately, the color output characteristics of different display devices can differ significantly. A cathode ray tube (CRT) or flat panel display, video card, driver software, and operating system together determine how RGB pixel values will be rendered and displayed, and vary significantly from system to system.
- Consequently, an online customer may order what appears to be a burgundy sweater but instead receive a bright red sweater. Indeed, color inaccuracy has become a significant cause for return of merchandise purchased by online customers. In some cases, this problem can erase the advantages obtained by the retailer's commitment in to online merchandising, and undermine continued investment.
- The invention relates to improvement of color image display accuracy in a computer network having display devices with different color output characteristics. The invention, in one embodiment, makes use of gray elements in the form of complex, non-rectangular shapes such as numerals, letters, and the like to aid in a blackpoint estimate for characterization of each display device.
- In particular, rows or columns of non-rectangular shapes with varying gray values can be displayed against a black background that serves as a reference background. The blackpoint can be estimated by selection of one of the shapes, rows, or columns that appears to most closely match the background. The use of complex, non-rectangular shapes to determine blackpoint can help resolve minor differences in R, G, and B that can cause poor gray balance.
- Instead of patches or bars, which may be generally rectangular, more complex shapes can be used to aid the human eye in resolving such differences. Numerals, letters, and other complex shapes that are substantially non-rectangular, for example, engage the pattern recognition capabilities of the human eye and can result in heightened sensitivity to gray scale differences. When the human eye is called upon to perform pattern recognition, its sensitivity to color gradations between a given pattern and a surrounding area increase. The complex shape generally presents a longer boundary relative to simple shapes, and promotes an increased perimeter for contrast.
- In some embodiments, three separate blackpoints can be estimated, one for each of the color channels of the display device, e.g., red, green, and blue (R, G, and B). Estimation of multiple, channel-specific blackpoints is based on the realization that some display devices, such as CRT monitors, exhibit very different blackpoints for different color channels, and can be difficult to characterize using only a single RGB blackpoint estimate. By estimating the blackpoint for each color channel (R, G, B) individually, a more accurate characterization of the overall calorimetric response of the display device can be obtained.
- A more accurate calorimetric characterization, which may result from the use of complex shapes in the blackpoint estimate, enables greater accuracy in a process for modification of color images that are delivered to and displayed on a particular display device. In this manner, the invention can provide improved color image display accuracy. This can be achieved, for example, by obtaining the multi-channel blackpoint estimate and other information characterizing the color response of a display device associated with a client device residing on a computer network.
- The information can be used advantageously to modify color images delivered to the client over a computer network such as the World Wide Web. The invention, in various embodiments, may be applied to provide color imagery modifications that compensate for the color response of the individual display device associated with the client. The display device may take the form of a cathode ray tube monitor, flat panel display, or similar color image display device. The multi-channel blackpoint estimate and additional information can be obtained, for example, by guiding the client through a color profiling process that profiles the color response of the display device. Guidance may take the form of a series of instructional web pages that are delivered to the client.
- The web pages can be made interactive to enable collection of color characterization data from the client. The color characterization data can be used to estimate a variety of information concerning display device characteristics such as the multi-channel blackpoint estimate, gamma, gray balance, and the like. Once the information has been collected, a color profile can be created for the client's display device, and thereafter used for modification of color images delivered to the client. The color profile can be incorporated in information that is transmitted by the client to an image server for modification of color images to be delivered to the client. The information transmitted by the client can be embodied in a web cookie or other content container.
- A very accurate value for average gamma of RGB can be determined using a series of cascading steps. In some embodiments, for example, a gray patch selected for the coarse gamma measurement is used as the central patch for a range of gray patches used to measure a more finely tuned gamma. The term “gray,” as used herein, generally refers to a color formed by combinations of two or more color channels of various gray levels, in contrast to colors formed by single color channels. The fine gamma then can be used to form the central gray patch for gray balance determination. Advantageously, in some embodiments, the user can complete the color profiling process in as few as four clicks, while gray balance determinations can be completed in a single click.
- A cookie, or alternative container, can provide a persistent representation of the color response characteristics of the client's display device. Each time the client accesses a web server and color images are identified in web page content, the cookie can be sent to the appropriate image server to improve the accuracy of the color image displayed on the client's display device. The cookie may contain a computed color profile for a display device or parameters useful in computing such a color profile and thereby rendering color modifications, or “corrections,” to images provided to a client.
- With improved color image accuracy, the images viewed by the client appear as intended. The system and method are capable of providing accurate characterization of a display device, while affording reliability and ease of use for the user. In a retail context, for example, the color of an item of interest more closely matches the actual color. As a result, items ordered by online customers are less likely to be returned based on color mismatch. Online retailers suffer from less returns, and online customers can shop with greater confidence that the items they order will arrive in the expected color.
- In general, users viewing online images are able to see the colors intended by the original source without the need for significant adjustments to the display device. Improved color image accuracy can thereby enhance the online experience for the client. At the same time, in many embodiments, the user need not be burdened with downloadable plug-ins, client side scripts, and the like, which can consume time and precious attention span. Instead, in preferred embodiments, the color profiling process can be carried out by execution of web pages.
- In one embodiment, the invention provides a method comprising displaying gray elements against a background, wherein each of the gray elements has a different gray value and a non-rectangular shape, and estimating a blackpoint for a display device based on one of the gray elements selected by the user that appears to most closely match the background.
- In another embodiment, the invention provides a system comprising a web server residing on a computer network, the web server transmitting web pages to remote clients residing on the computer network, a color image server residing on the computer network, the color image server transmitting color images referenced by the web pages to the clients for display on display devices associated with the clients, a color profile server residing on the computer network, the color profile server guiding the clients through a color profiling process to obtain information characterizing the color responses of the display devices associated with the clients, wherein the information includes a blackpoint estimate for the color channels of the display devices, and the color profiling process includes displaying gray elements against a black background, wherein each of the gray elements has a different gray value and a non-rectangular shape, selecting one of the gray elements that appears to most closely match the black background, and estimating the blackpoint for a display device based on the selected gray element, and one or more color correction modules that modify the color images transmitted by the color image server based on the information to improve the accuracy of the color images when displayed on the respective display device.
- In an added embodiment, the invention provides a computer readable medium containing program code that causes a programmable processor to display gray elements against a background, wherein each of the gray elements has a different gray value and a non-rectangular shape, and estimate a blackpoint for a display device based on one of the gray elements selected by the user that appears to most closely match the background.
- The details of one or more embodiments of the present invention are set forth in the accompanying drawings and the description below. Other features, objects, and advantages of the present invention will be apparent from the description and drawings, and from the claims.
- FIG. 1 is a block diagram of a system for improving color image display accuracy in a computer network;
- FIG. 2 is a block diagram of a web-based environment incorporating a system as shown in FIG. 1;
- FIG. 3 is a flow diagram illustrating a method for improving color image display accuracy in a computer network;
- FIG. 4 is a flow diagram illustrating a color profiling process for a display device;
- FIG. 5 is a flow diagram illustrating a multi-channel blackpoint determination in a color profiling process as shown in FIG. 4;
- FIG. 6 is a diagram of a web page for analog adjustment of a color display prior to blackpoint determination;
- FIG. 7 is a diagram of a web page for determination of blackpoint for a particular color channel;
- FIG. 8 is a flow diagram illustrating gamma and gray balance determination in a color profiling process as shown in FIG. 4;
- FIG. 9 illustrates a range of gray elements for use in determining a coarse gamma in a color profiling process as shown in FIG. 4;
- FIG. 10 illustrates a range of gray elements for use in determining a fine gamma in a color profiling process as shown in FIG. 4;
- FIG. 11 illustrates a range of gray elements for use in determining gray balance in a color profiling process as shown in FIG. 4;
- FIG. 12 illustrates an example of a color image transmitted to a client in a system as shown in FIGS. 1 and 2;
- FIG. 13 is block diagram illustrating transmission of color correction information in a system as shown in FIGS. 1 and 2; and
- FIG. 14 is a block diagram illustrating an alternative architecture for a system for improving color image display accuracy in a computer network.
- FIG. 1 is a block diagram of a
system 10 for improving color image display accuracy across a computer network. The computer network may take the form of a local area network, wide area network, or global computer network such as the World Wide Web. In accordance with one embodiment,system 10 can be configured to obtain multi-channel blackpoint estimate that characterizes the colorimetric response of a display device associated with a client on the network. In particular, three separate blackpoints can be estimated, one for each of the color channels of the display device, e.g., red, green, and blue (R, G, and B). Estimation of multiple, channel-specific blackpoints is based on the realization that some display devices, such as CRT monitors, exhibit very different blackpoints for different color channels, and can be difficult to characterize using only a single RGB blackpoint estimate. By first estimating the blackpoint for each color channel (R, G, B) individually, instead of only an overall RGB blackpoint, a more accurate characterization of the calorimetric response of the display device can be obtained. - As shown in FIG. 1,
system 10 may include aweb server 12, aclient 14, acolor image server 16, and acolor profile server 18.Web server 12 providesclient 14 with access to web pages incorporating graphic content such as color images. Some of the color images can be incorporated in the web pages stored atweb server 12 while other color images are stored atcolor image server 16.Web server 12 may store lower resolution color images, for example, as well as images that are less color-intensive. Higher resolution color images and more color-intensive images can be stored atcolor image server 16. -
Web server 12,client 14,color image server 16, andcolor profile server 18 each execute program code that is stored on computer-readable media residing locally with the respective device or executed remotely. Forclient 14, for example, the program code may reside in random access memory (RAM) that is accessed and executed by the client computer. The program code can be loaded into the memory from another memory device, such as a fixed hard drive or removable media device associated withclient 14. In particular, the program code can be initially carried on computer-readable media such as magnetic, optical, magneto-optic or other disk or tape media, or electronic media such as EEPROM. Alternatively, the program code can be loaded into the medium by transmission from a remote data archive, e.g., via a local area network, wide area network, or global network such as the Internet. A substantial portion of the code may be web page code that is transmitted to the respective device and executed by a server or browser application. - Web page code, e.g., Hypertext Markup Language (HTML), Extensible Markup Language (XML), or the like, generated by
web server 12 may include image tags that point to specific color images stored atcolor image server 16 or elsewhere. Whenclient 14 accesses a particular web page delivered byweb server 12 and executes the HTML to assemble the page content,color image server 16 is accessed to obtain any images tagged within the web page code. Thus, the content of a web page assembled forclient 14 may include objects obtained from different resources within the network occupied bysystem 10, such asweb server 12 andcolor image server 16. In some embodiments,web server 12 andcolor image server 16 may be integrated with one another. In the example of FIG. 1, however,color image server 16 andweb server 12 are separate entities.Web server 12 andcolor image server 16 each may interact with a database server and file server to obtain access to selected color images for delivery toclient 14. -
Client 14 may take the form of a variety of devices that permit a user to access resources onsystem 10 and display color images obtained from such resources. Examples ofclient 14 include desktop or portable computers operating in a Windows, Macintosh, Unix, or Linux environment, personal digital assistants (PDA's), based on the Palm, Windows CE, or similar operating system environments for small portable devices, Internet-equipped wireless telephones, interactive televisions with set-top boxes for Internet access, Internet kiosks available to the general public, and future Internet appliances that may emerge. Eachclient 14 preferably executes a graphical viewing application such as a web browser to access resources residing on other resources, such asweb server 12 andcolor image server 16, attached tosystem 10. A web browser application permits the user associated withclient 14 to readily view web pages generated byweb server 12, and images served bycolor image server 16. Other user interface applications may be useful in accessingweb server 12 provided the information is presented in a user-interactive format. - In some embodiments,
color image server 16 may be configured to deliver color corrected video imagery, in addition to static images. Video, such as MPEG clips, streaming video, and the like may suffer from similar color accuracy issues if they are not compensated for the effects of the display device associated with anindividual client 14. Thus, some embodiments of the invention may be particularly useful for broadcast-like video content. - In each case,
client 14 includes a display device, such as a cathode ray tube or flat panel display, for display of color images obtained fromweb server 12 andcolor image server 16. Other types of displays as well as dynamic viewing media such as electronic paper are contemplated. Communication betweenweb server 12,client 14, andcolor image server 16 may take place using conventional network protocols such as TCP/IP. Although some of the client devices described above, such as PDA's and wireless telephones, presently incorporate relatively low quality color displays, it is anticipated that such devices will benefit from higher quality color displays in the near future. Accordingly,system 10 will be readily applicable in enhancing the quality of color images displayed by PDA's, wireless telephones, and similar devices in the future. - As an illustration,
web server 12 may deliver web pages associated with an online retailer such as a clothing merchandiser. In this example, the web pages delivered byweb server 12 may contain information concerning an array of items offered for sale by the retailer, as well as color images of the items for viewing by online customers. Some of the color images may constitute low resolution “thumbnail” images placed coincident with hypertext links to higher resolution images stored atcolor image server 16.Client 14 executes the code delivered byweb server 12 within a browser application to assemble a web page for display on a display device associated with the client. - When a user associated with
client 14 clicks on one of the thumbnail images with a pointing device, such as mouse, trackball, pen, or the like,client 14 accessescolor image server 16 to obtain the higher resolution color image designated by an image tag embedded in the web page code. To permit display of the higher resolution color image with greater color accuracy,color image server 16 modifies the color image based on information obtained forclient 14. In particular,color image server 16 obtains information characterizing the color response of a display device associated withclient 14. The information can be uploaded tocolor image server 16, e.g., in the form of a web cookie or other content container. Alternatively, the information can be transmitted, i.e., broadcasted, to a number of subscriber color image servers insystem 10, which are recognized bycolor profile server 18. The information can be generated by guiding a user associated withclient 14 through a color profiling process that profiles the color response of the display device. - When
client 14 accesses a color image fromcolor image server 16, the user may be given a choice between viewing a version of the image with default color settings, or initiating the color profiling process to produce custom color settings for the user's display device and thereby improve the quality of the color image. In particular, the color image delivered bycolor image server 16 may be embedded in a web page with one or more hypertext links for initiation of the color profiling process through interaction withcolor profile server 18. When the user clicks on the hypertext link,client 14 accessescolor profile server 18 for delivery of a series of instructional web pages to the user. - The instructional web pages provided by
color profile server 18 guide the user through a number of steps designed to estimate the color response characteristics of the particular display device associated withclient 14. When the process is complete,color profile server 18 delivers a web page with content that, when executed, generates a cookie containing the color profile information. The cookie then can be uploaded tocolor image server 16 for use in modifying the color image, and subsequently accessed color images, to produce higher quality color output on the display device associated withclient 14. Exemplary color profiling processes will be described in greater detail later in this detailed description. - Other techniques for obtaining the color profiling information may not require direct interaction by the user with a
color image server 16 a-16 n. Instead, the user may voluntarily visit a web site to perform color profiling. The web site may be provided bycolor profile server 18 or be within the same domain as the color profile server. Alternatively, users may profile the display devices associated with theirindividual clients 14 a-14 n by executing software downloaded or physically delivered to them. Moreover, display devices could be configured to produce a color profile when put in use, and transmit the color profile to subscriber color image servers, e.g., in a cookie. In each case,color profile server 18 receives essentially the same information for transfer to a number of individual color image servers for delivery of color corrected images toclient 14. - FIG. 2 is a block diagram of a web-based
environment 20 incorporating a system as shown in FIG. 1. Web-basedenvironment 20 includes a number ofsubscribers subscriber individual clients color image server 16 a-16 n, and maintains web pages that invoke the high quality images at arespective subscriber server 12 a-12 n. Note that there may be manymore clients 14 a-14 n than subscribers 22 a-22 n. - One of the
subscriber servers 12 a-12 n and one of thecolor image servers 16 a-16 n preferably are under the control of the respective subscriber. In other words,subscriber 22 a may be responsible for maintenance, administration, and content ofsubscriber server 12 a andcolor image server 16 a, whilesubscriber 22 b is responsible forsubscriber server 12 b andcolor image server 16 b. In this manner, subscribers 22 a-22 n can readily update the contents ofsubscriber servers 12 a-12 n andcolor image servers 16 a-16 n themselves. Consequently, subscribers 22 a-22 n do not need to relinquish control of their image content to some third party in order to take advantage of the color image quality improvements contemplated in accordance with this embodiment of the invention. Instead, subscribers 22 a-22 n make use of their owncolor image servers 16 a-16 b and interaction with acolor profile server 18 that guides the color profiling process forclients 14 a-14 n. Nevertheless, in some embodiments, use of a central image server for all subscribers may be desirable. The commercial entities associated withsubscriber servers 12 a-12 b andcolor image servers 16 a-16 n are “subscribers” in the sense that they all make use of color profiles generated by interaction with one or more commoncolor profile servers 18. Thus, a subscriber may be a retailer or collection of retailers with a web site that employs color correction as described herein, and makes use ofcolor profile server 18.Subscriber server 12 a-12 n may be the subscriber's main web server.Color image server 16 a-16 n can be a server that is co-located with or remotely located from acorresponding subscriber server 12 a-12 n and contains the subscriber's high resolution or color-intensive color images and a color correction module for modifying the images and serving corrected images toclients 14 a-14 n. Eachcolor image server 16 a-16 n may be within the domain of therespective subscriber server 12 a-12 n, but this is not a requirement. Thus, in the environment of FIG. 2,clients 14 a-14 n are potential customers of subscribers 22 a-22 n who view the subscriber's web pages with their own browsers. -
Clients 14 a-14 naccess subscriber servers 12 a-12 n,color image servers 16 a-16 n, andcolor profile server 18 viaWorld Wide Web 24. Although the number ofclients 14 a-14 n and subscribers 22 a-22 n shown in FIG. 1 is limited for ease of illustration, the actual number can be virtually unlimited subject to the bandwidth limitations ofsubscriber servers 12 a-12 n,color image servers 16 a-16 n,color profile servers 18 andweb 24. With a large number ofclients 14 a-14 n accessing subscribers 22 a-22 n, the color responses of individual display devices can be quite varied. The color profiling process and color image modifications administered bycolor profile server 18 andcolor image servers 16 a-16 n, however, compensate for differences between the various client display devices and thereby increase the consistency of color output viewed by users situated acrossweb 24. If subscribers 22 a-22 n are clothing retailers, for example, the color images viewed byclients 14 a-14 n on disparate display devices can be made to more closely match the color of actual clothing items. - FIG. 3 is a flow diagram illustrating a method for improving color image display accuracy in a computer network as shown in FIGS. 1 and 2. When a
client 14 seeks to download a web page from asubscriber server 12, the client receives HTML code (or some other form of web page code) with embedded image tags identifying the locations of color images to be incorporated in the web page when it is presented on a display device, as indicated byreference numeral 40. For lower resolution images, such as so-called “thumbnails,” the image tags may point to locations resident atsubscriber server 12. When a user clicks on a thumbnail to access a higher resolution image, or when a higher resolution is embedded in the web page in the first instance,client 14 executes the web page code to access and download color images from a designatedcolor image server 16, as indicated byreference numeral 42 in FIG. 3. - In the example of FIG. 3, the web page code executed by
client 14 for access tocolor image server 16 queries whether a color profile cookie visible to the color image server has been generated for the particular client, as indicated byreference numeral 44. A cookie is visible, for example, if it corresponds to the domain of the color image server. Management of cookies will be described later in this description. The color profile cookie contains information characterizing the color response of the display device associated withclient 14, and resides locally with the client. If a color profile cookie has been generated,client 14 uploads the cookie tocolor image server 16, as indicated byreference numeral 46.Color image server 48 retrieves the image requested byclient 14 and modifies the image based on the contents of the cookie by applying a color correction, as indicated byreference numeral 48. The color correction modifies the image to compensate for variations in the color response characteristics of the display device associated withclient 14.Color image server 16 then downloads the color corrected image toclient 14, as indicated byreference numeral 50, and the process ends, as indicated by reference numeral 52. In the above manner,client 14 receives a color corrected image that is customized for the client's display device to provide more accurate color output. - If a color profile cookie has not been generated previously,
client 14 downloads a default color image fromcolor image server 16, as indicated byreference numeral 54, for presentation on the display device associated with the client. The image is a “default” image in the sense that it has not been color corrected or otherwise customized for the individual display devices associated withclient 14. As a result, when displayed byclient 14, the default image may exhibit significant color inaccuracy relative to the original color image. With the default image, however,client 14 may present a color profiling option, as indicated byreference numeral 56. In particular,client 14 may download with the image an indication of whether color profiling and correction has been applied to the image. With the image,client 14 may display that indication along with a hypertext icon that may invite the user to carry out color profiling. The user may click on the profiling icon with a pointing device to access the color profiling process. In some embodiments, the profiling icon may indicate that profiling has already been performed and that the image has been color corrected, e.g., by displaying the icon in color. If profiling has not been performed previously, the icon may be displayed in black-and-white or some other indication can be provided. By clicking on the icon, the user can commence profiling, either in the first instance or as a profiling update. - If the option is not selected, as determined at
reference numeral 58, the user simply views the default image and the process ends, as indicated by reference numeral 52. If the option is selected, however,client 14 executes code that directs it to accesscolor profile server 18, e.g., via the hypertext link associated with the icon.Color profile server 18 guides the user associated withclient 14 through a color profiling process, as indicated byreference numeral 60. The color profiling process produces information characterizing the color response exhibited by the display device associated with theparticular client 14. Following completion of the color profiling process,client 14 generates a color profile cookie, as indicated byreference numeral 62. The color profile cookie contains the color characterization information.Client 14 then uploads the color profile cookie to color image server, as indicated byreference numeral 46, to obtain a color corrected image for improved color image accuracy. As will be explained, the cookie may need to be rewritten for the domain of thecolor image server 16. - Notably, as will be described, the color profiling process optionally requires no plug-ins, Java scripts, or other significant client-side processes. Instead, interaction between
subscriber server 12,client 14,color image server 16, andcolor profile server 18 is driven by execution of the web page code delivered toclient 14. This approach yields significant convenience for the end user associated withclient 14. At the same time, subscribers 22 a-22 n are not required to retain color information for individual users. Rather, the information can be uploaded tocolor image server 16, e.g., in the form of a cookie, whenever color images are requested by aclient 14. Moreover, subscribers 22 a-22 n can maintain their own color images atcolor image servers 16 a-16 n, and provide color correction by incorporating a color correction module capable of handling the color profile cookies uploaded byindividual clients 14 a-14 n. Accordingly, there is no need for subscribers 22 a-22 n to post their web pages or images to a central web repository. - To carry out a color profiling process as described with reference to FIG. 3,
client 14 interacts withcolor profile server 18.Color profile server 18 delivers a series of web pages toclient 14. Each of the web pages is designed to guide the user through a given step in the color profiling process. One web page, for example, may include instructions and image content designed to extract from the user an estimate of the blackpoint of the display device. In one embodiment, the blackpoint estimate may be an estimate of multiple, channel-specific blackpoints. Other web pages may include instructions and content designed to extract coarse gamma, fine gamma, and gray balance information. In particular, each web page may include interactive media such as hypertext icons and the like that can be clicked upon by the user to transfer information fromclient 14 tocolor profile server 18. - Upon collecting the necessary information,
color profile server 18 creates the cookie and delivers it toclient 14 for local storage and future use. In some embodiments, two cookies can be provided toclient 14. A first cookie may correspond to a domain name associated withcolor profile server 18, and be used for future interactive between theparticular client 14 a-14 n and the color profile server. The first cookie can be referred to as the “profiler cookie.” A second cookie may correspond to a domain name associated with the particularcolor image server 16 a-16 n (corresponding to a particular subscriber such as a retailer) from which the color image is to be downloaded. In other words, the second cookie may correspond to the color image server 168 a-168 n at which the color profiling process was initiated. In this manner, future images delivered by thatcolor image server 16 a-16 n will be modified based on the contents of the cookie associated with the pertinent domain. The second cookie can be referred to as the “subscriber cookie.” - The profiler cookie can be used to produce additional subscriber cookies for use with
color image servers 16 a-16 n associated with other domains. Specifically, when a user situated at aclient 14 a-14 n accesses acolor image server 16 a-16 n from which the user has not previously downloaded color corrected images, the user can click on the color profiling option and be directed tocolor profile server 18. Upon interaction withcolor profile server 18,client 14 simply uploads the profiler cookie instead of repeating the color profiling process. Information concerning the domain associated with the newcolor image server 16 a-16 n can be incorporated in the profiler cookie. - In response to receipt of the profiler cookie,
color profile server 18 delivers a web page advising the user associated withclient 14 a-14 n of the intent to send the cookie contents to the domain indicated in the cookie, and may request user approval for, among other reasons, privacy concerns. Upon approval by the users,color profile server 18 transmits the cookie contents to thecolor image server 16 a-16 n designated by the domain in the profiler cookie. In response, thecolor image server 16 a-16 n creates a subscriber cookie for its own domain, and writes the cookie toclient 14 a-14 n for future use. Thereafter,client 14 uploads the appropriate subscriber cookie to the pertinentcolor image server 16 a-16 n when requesting color corrected images for the pertinent subscriber 22 a-22 n, and can bypass interaction withcolor profile server 18. - The reliance on first and second cookies, one for
color profile server 18 and the other for aparticular subscriber server 12 a-12 n orcolor image server 16 a-16 n, is driven in part by existing web design considerations. In particular, cookies stored on a client's browser typically are marked by the domain of the server that generates them, and are not generally visible to other domains. Thus, cookies created bycolor profile server 18 are not generally visible tocolor image servers 16 a-16 n, and vice versa. Further, cookie visibility can be further restricted by marking the cookie with a path within a server's domain. This sort of cookie will then not be visible on requests to pages outside the path, even if to the same domain. Further, a browser routinely sends all visible cookies on each request to a server. This includes not only the initial request for an HTML page, but also the requests for images to be embedded in the page. Because an image can come from a different server than the HTML page, however, the cookies sent for the HTML page can differ from those sent for the image. - In light of the above considerations,
color profile server 18 acts as an intermediary not only for administration of the color profiling process, but for generation of subscriber cookies. This intermediary function enables color correction of all subscriber images to be performed atcolor image servers 16 a-16 n rather than at a centralized site. Also, with this intermediary function, once a client has gone through the color profiling process, he generally will not have to repeat it to obtain color correction of images for additional subscribers. As an exception, the user may voluntarily repeat the color profiling process when local driver software or hardware such as the display device or video card associated with aclient 14 a-14 n has changed. Indeed, to encourage updates from time to time in order to accommodate hardware changes, expiration dates can be applied to the profiler cookie and subscriber cookies. - It is apparent that the three different servers, i.e.,
subscriber server 12 a-12 n,color image server 16 a-16 n, andcolor profile server 18, divide the labor involved in color correction transactions. In particular, assuming the existence of a profiler cookie and a subscriber cookie, asubscriber server 12 a-12 n serves the HTML for the subscriber's own web pages and handles most other requests for those pages, including serving of images that are not subject to color correction.Color image server 16 a-16 n serves the images that are subject to color correction. - If
color image server 16 a-16 n receives the appropriate subscriber cookie, it performs color correction based on the cookie contents and serves the color corrected image to theappropriate client device 14 a-14 n.Color image server 16 a-16 n also may serve an icon near the correctable color images that indicates whether the color images have indeed been corrected. Ifcolor image server 16 a-16 n finds no subscriber cookie, for example, it displays an icon suggesting that the user click the icon to initiate the color profiling process. Otherwise, the icon merely indicates that color correction is turned “on,” i.e., that color correction has been applied to the image. -
Color profile server 18, as mentioned above, serves the pages for the color profiling process. If the color profiling process is invoked by clicking the icon displayed with a color image delivered bycolor image server 16 a-16 n, therespective client 14 a-14 n probably does not have a subscriber cookie for the pertinent subscriber 22 a-22 n. In some cases, however,client 14 a-14 n may be voluntarily repeating the color correction process to update the profile for new hardware or software. If a profiler cookie exists, then the process can be abbreviated by simply shipping the contents of the cookie to the appropriate subscriber domain for creation of the subscriber cookie. - If the profiler cookie does not exist, then the full color profiling process is served by
color profile server 18. Upon completion of the color profiling process,color profile server 18 generates the profiler cookie forclient 14 a-14 n, and passes the contents of the profiler cookie to the pertinentcolor image server 16 a-16 n.Color image server 16 a-16 n then generates the subscriber cookie based on the profiler cookie contents and invokes the original subscriber URL from which the color profiling process was invoked. - The mechanisms for exchanging color correction information between the profiler cookie generated by
color profile server 18 and the subscription cookie generated bycolor image server 16 a-16 n may vary. In particular, rather than delivering cookies toclients 14 a-14 n,color profile server 18 may be arranged to transmit the color correction information to all of thecolor image servers 16 a-16 n associated with a recognized group of subscribers 22 a-22 n. In this manner, the color profile information obtained bycolor profile server 18 as a result of the color profiling process can be “broadcasted” for storage by subscribers 22 a-22 n. The advantage of this approach is that information transfer is seamless. There is no need for the user associated with aclient 14 a-14 n to interact withcolor profile server 18 following the initial color profiling process, other than to update the color profile. Rather, each subscriber 22 a-22 n stores the color correction information associated with theindividual client 14 a-14 n, e.g., with a client ID code. - When the
client 14 a-14 n accesses one of thecolor image servers 16 a-16 n, the client ID code is used to retrieve the appropriate color correction information and thereby serve a color corrected image. The downside is that each subscriber 22 a-22 n needs to maintain a database of color correction information forclients 14 a-14 n requesting color corrected images from the participating subscribers, including clients who may never access arespective subscriber server 12 a-12 n. Thus, an approach that makes use of cookies for transfer of color correction information may be more desirable for some subscribers 22 a-22 n. Nevertheless, broadcasting of color correction information remains a viable option that may be acceptable to some subscribers 22 a-22 n, and highly convenient for end users. - The following is a description of some of the details that may be associated with passing information between
subscriber servers 12 a-12 n,clients 14 a-14 n,color image servers 16 a-16 n, andcolor profile server 18 according to an indirect cookie transfer approach. This approach is indirect in the sense that the user intervenes and enters approval before the profiler cookie contents are transferred fromcolor profile server 18 to a respectivecolor image server 16 a-16 n. In delivering web pages toclients 14 a-14 n,subscriber servers 12 a-12 n pass the URL's for correctable images stored on associatedcolor image servers 16 a-16 n. In addition,subscriber servers 12 a-12 n preferably incorporate color profiling icons near the images. The URL's for the color profiling icons point to the pertinentcolor image server 16 a-16 n, while the hypertext link associated with the icon points tocolor profile server 18. - To accomplish passing of color correction information back to
color image server 16 a-16 n, the URL of the page viewed by the user is passed tocolor profile server 18 when the hypertext link associated with the icon is followed by aclient 14 a-14 n. - This step of passing the URL can be accomplished either by including the URL as a parameter on the target URL, or by POSTing the information from a form that wraps the icon, i.e., with the URL stored in a hidden entry field. In the latter case, the icon serves as a button, which may require some minimal client-side scripting. In addition, as will be described, the name of the subscriber22 a-22 n and the URL of a completion page to be served by the
color image server 16 a-16 n after the color profiling process is complete may be included in the request tocolor profile server 18. Subscribers 22 a-22 n can be provided with a server-side scripting function that inserts the icon code with the appropriate URLs. - For the color profiling process,
color profile server 18 serves a number of web pages that can be invoked by execution of a web page provided bysubscriber server 12 a-12 n. In this case, the “return URL” is passed forward to each page in the sequence. - The return URL can be passed as a parameter in the target URL, or by using hidden fields in forms. In some cases, the return URL can be stored as a server variable. As mentioned above,
color profile server 18 handles two scenarios: (1) full color profiling when no profiler cookie exists, and (2) creation of a subscriber cookie when a profiler cookie already exists. In both scenarios,color profile server 18 transfers the contents of the existing or newly created profiling cookie to the pertinent subscriber 22 a-22 n. In particular,color profile server 18 may present a button that requests permission of the user associated withclient 14 a-14 n to transfer the information. - The URL for the button points to a page served by
color image server 16 a-16 n. - The request sent to
color image server 16 a-16 n includes both the return URL and the color information written in the profiler cookie. The request preferably is a POST request from a form, rather than a GET request with all the information set forth in the URL due to length considerations.Color profile server 18 determines the URL of the destination page at subscriber 22 a-22 n by reference to the return URL. Prior to transfer of the cookie contents, the user will want to know the destination. Accordingly,color profile server 18 displays the name of the particular subscriber 22 a-22 n along with the button. If the name of the subscriber is not easy to determine from the URL, it can be generated by cross-referencing the URL to a name in a database accessible bycolor profile server 18, or by passing the name with the return URL in the original request from the page generated bysubscriber server 12 a-12 n. - Upon receipt of the information from
color profile server 18, the pertinentcolor image server 16 a-16 n serves a page indicating that the color profiling process is complete. The page may be invoked by the POST request containing the color correction information and the URL of the “return” page, as received fromcolor profile server 18.Color image server 16 a-16 n writes the color correction information to thepertinent client 14 a-14 n as a client cookie. From that point forward, the subscriber cookie is stored by therespective client 14 a-14 n, and is sent to thecolor image server 16 a-16 n associated with the pertinent subscriber 22 a-22 n with any request for a color correctable image. In response,color image server 16 a-16 n extracts the contents of the subscriber cookie, applies a color correction to the requested image based on the contents, and delivers the color-corrected image to theclient 14 a-14 n. - As an alternative approach, color correction can be passed from
color profile server 18 to thecolor image server 16 a-16 n associated with the respective subscriber 22 a-22 n via a direct request, rather than being embedded in a request generated whenclient 14 a-14 n clicks on a button, anchor, or other input medium. This approach is direct in the sense that the user need not intervene by submitting approval for the transfer tocolor profile server 18. Instead, the transfer of the content of the profile cookie to the appropriatecolor image server 16 a-16 n can be made seamless. Indeed, in preferred embodiments, the user associated withclient 14 a-14 n does not even view pages sent bycolor profile server 18 for transfer of information following the initial profiling. In this manner, the transfer of color correction information fromcolor profile server 18 to acolor image server 16 a-16 n happens automatically, without requiring the user associated with aclient 14 a-14 n to click on a link to effect the transfer. This approach makes the transfer appear more seamless to the user. The end result is the same, i.e., the transfer of color correction information contained in a profiler cookie to create a subscriber cookie without the need for reexecution of the color profiling process by the user. - To facilitate transfer by direct request, the
client 14 a-14 n is assigned a client ID. Ordinarily, the client ID can be stored in and received from a subscriber cookie on the browser associated with aclient 14 a-14 n. Aclient 14 a-14 n that is new to the particular subscriber 22 a-22 n, i.e., a client that does not send a subscriber cookie to the particularcolor image server 16 a-16 n, will be assigned a new client ID, which is sent as a cookie with the HTML in the response from the color image server. All URLs pointing tocolor profile server 18 then bear both the client ID and a subscriber ID as parameters, so that the color profile server can correlate requests for color correction information for therespective client 14 a-14 n. The URL for the color profiling icon points tocolor profile server 18 if there is no subscriber cookie. For this approach, it is preferred that therespective subscriber server 12 a-12 n and correspondingcolor image server 16 a-16 n occupy the same domain so that they can view the same cookies. - As in the indirect approach, a color profiling icon, which appears adjacent a color correctable image, may be served from either
color image server 16 a-16 n orcolor profile server 18 in the direct transfer approach, depending on whether the color image server receives a subscriber cookie. If a subscriber cookie is present, the profiling icon is served bycolor image server 16 a-16 n, and is formulated in appearance to indicate that color correction is active, e.g., with a text message to that effect. This will be the case for most images served bycolor image server 16 a-16 n because onlynew clients 14 a-14 n will not have the subscriber cookie. - If the subscriber cookie is not presented, the icon is served by
color profile server 18. In other words, the web page served bycolor image server 16 a-16 n has embedded in it an icon served bycolor profile server 18. If a profiler cookie is present,color profile server 18 serves an icon that indicates theclient 14 a-14 n has already been through the color profiling process. If not, the icon indicates that the color profiling process has not previously been completed by therespective client 14 a-14 n. This may be represented by a colored icon to indicate that color profiling has been completed, and a black-and-white icon to indicate that it has not. - In some embodiments, the icon may indicate that the
client 14 a-14 n has been through the color profiling process, but that the color correction information has not yet been forwarded to the particular subscriber 22 a-22 n, and that the image has not been color corrected. In either case,color profile server 18 also receives the ID for theclient 14 a-14 n and the subscriber 22 a-22 n, which are included in the URL forwarded tocolor profile server 18. If the profiler cookie is present,color profile server 18 immediately forwards the client ID and the contents of the profiler cookie to the pertinentcolor image server 16 a-16 n in a special-purpose request. - If the subscriber cookie is present,
color image server 16 a-16 n performs the color correction based on the information contained in the cookie. If the subscriber cookie is not present,color image server 16 a-16 n waits a short time to receive color information for this client fromcolor profile server 18. If the information is forthcoming,color image server 16 a-16 n applies the color correction and writes a subscriber cookie to the browser associated with theclient 14 a-14 n. Otherwise,color image server 16 a-16 n serves an uncorrected image. - With this direct approach, it may be necessary for
color image server 16 a-16 n to keep track of color correction information forwarded by thecolor profile server 18 because such information may not be received synchronously with image requests fromclients 14 a-14 n. Accordingly, it may be necessary to incorporate a database application that can be shared bycolor image server 16 a-16 n for temporary tracking of color correction information associated withindividual clients 14 a-14 n, andsubscriber server 12 a-12 n for tracking and generation of client ID information. Once the information has been written to a subscriber cookie, the ID and color correction information for therespective client 14 a-14 n can be purged from the database. - Management of ID's according to the direct transfer approach may take place as follows. The original color correction information generated by
color profile server 18 can be stamped with a unique ID. The unique ID can be maintained in copies of the color correction information forwarded to subscribers 22 a-22 n. This ID changes if theclient 14 a-14 n repeats the color profiling process, and can be referred to as the profiler ID. The profiler ID will remain unchanged until the next pass through the color profiling process, which may occur months later. In effect, the profiler ID corresponds to a particular color profiling sequence. The profiler ID is supplemented by the client ID and the subscriber ID. The client ID identifies a client for whom a subscriber 22 a-22 n is requesting color information, and the subscriber ID identifies the particular subscriber. - The client and subscriber IDs are passed via URL parameters to
color profile server 18 whenever acolor image server 16 a-16 n has no color correction information for aparticular client 14 a-14 n. The subscriber ID is passed back with the color correction information fromcolor profile server 18 to thecolor image server 16 a-16 n when the color profile server determines the appropriate information for the client, based on the contents of a profiler cookie or the results of running the color profiling process. Oncecolor image server 16 a-16 n receives this information and writes it as a subscriber cookie to the client's browser, the subscriber ID is no longer needed. - FIG. 4 is a flow diagram illustrating a color profiling process for a display device. A process as shown in FIG. 4 can be used to generate the contents of a profiler cookie as discussed above with reference to FIG. 3. Notably, the entire color profiling process can be completed by the user with as few as three “clicks” of a pointing device. If the user is required to click a continue button to proceed after selecting a patch, the process may take additional clicks. If the user is permitted to proceed automatically following selection of a patch, however, the entire process can be completed in three clicks. With optional analog adjustment, separate R,G, and B blackpoints, and fine gamma steps, to be described, the process may require up to six or seven clicks. Also, in many embodiments, the color profiling process requires no plug-ins or client side scripting when utilizing the method of selecting discrete elements, although such mechanisms can be provided in some embodiments such as in the use of slider adjustments.
- The color profiling process enables visual profiling of a display device by determining accurate values of blackpoint and gamma for the R,G, and B phosphors or photodiode elements. Gamma refers to a parameter y that indicates the rate of change in light intensity with change in digital device value. The term “blackpoint” refers to the lowest RGB values capable of representation on the display device. For color values below the blackpoint, there is no further decrease in light emitted by the display device. Blackpoint is sometimes alternatively referred to as black onset. In accordance with the invention, three separate blackpoints are optionally determined, one for each of the R, G, and B color channels of the monitor. For use with more accurate monitors, a single dark gray RGB selection can be used to estimate a single average blackpoint value for R, G, and B.
- In some display devices, such as older CRT monitors, different color channels can produce very different blackpoints. Accordingly, reliance on a single RGB blackpoint measurement in generating a color profile can introduce inaccuracies. Determination of channel-specific blackpoints, however, can reduce the degree of inaccuracy. In other words, by estimating the blackpoint for each color channel individually, a more accurate characterization of the calorimetric response of the display device can be obtained. A more accurate colorimetric characterization enables greater accuracy in conversion of color images for delivery and display on the particular monitor. For purposes of example, alternative color profiling processes are disclosed in U.S. patent application Ser. No. 09/631,312, to Kruse et al., filed Aug. 3, 2000, and entitled “COLOR IMAGE DISPLAY ACCURACY ACROSS A GLOBAL COMPUTER NETWORK,” the entire content of which is incorporated herein by reference.
-
Color profile server 18 may administer a color profiling process as shown in FIG. 4 by serving a series of instructional web pages toclient 14 a-14 n. In general, the color profiling process may involve determination of (1) blackpoint for each of the red, green, and blue (R, G, and B) color channels of the display device, (2) average gamma for R, G, and B, and (3) differences in gamma for R, G, and B. Due to the wide range of differences in display device properties, determination (2) above can be subdivided into determination of (2a) a coarse gamma estimate, and (2b) a fine gamma estimate. This process is described in greater detail below with reference to FIGS. 4-11. - As indicated by
reference numeral 64 in FIG. 4, the color profiling process first involves determination of an estimated blackpoint for each of the color channels of the color display device, e.g., R, G, B. After determining the blackpoints, which may be merely an estimate, the color profiling process involves determination of the gamma exhibited by the display device. In particular, the process may involve determination of a coarse gamma, as indicated byreference numeral 66, followed by determination of a fine gamma, as indicated byreference numeral 68. Determination of the fine gamma may rely in part on the coarse gamma. In other words, the coarse gamma can be used as an initial estimate and starting point for convergence toward a more finely tuned gamma. - After determining the fine gamma, the process may involve determination of the gray balance exhibited by the display device, as indicated by
reference numeral 70 of FIG. 4. Gray balance provides an indication of the amount of color shift of a neutral gray toward one or more of the color channels used by the display device, e.g., red, green, and blue. The gray balance determination may rely in part on the gamma determined previously in the color profiling process and, in a particular embodiment, the fine gamma. Next, the color profiling process involves generation of a color profile, as indicated byreference numeral 72. The color profile contains information that characterizes the color response of the display device based on the determinations indicated byreference numerals client 14 for uploading to any ofcolor image servers 16 a-16 n when needed, as indicated byreference numeral 74. - The estimated blackpoint parameters define the dynamic range of the display device. Because the maximum RGB value always defines white, the blackpoint defines the black end point, and therefore defines the domain of values for each of the R, G, and B color channels that results in a continuous change from black to white. Again, blackpoint refers to the R, G, or B value below which there is no further decrease in light emitted by the display device. For an individual color channel, such as R, the blackpoint is the point at which further decreases in the R value produce no further decreases in R channel light emitted by the display device. If the blackpoint for a given color channel of a display device is high, values for that channel in darker regions will be mapped to the darkest shade and shadow detail will be lost if no image correction is performed. Accordingly, obtaining an accurate blackpoint estimate is important for the accuracy of images represented by the display device.
- In addition to a multi-channel blackpoint estimate, the color profile may include a gamma parameter and a gray balance parameter. The parameters together define the colorimetric response of an individual display device to enable modification of color imagery for more accurate representation on the device. The gamma parameter most affects the overall appearance of the image. Gamma determines whether an image appears overall too light or dark, or with too much contrast or too little. The third parameter, R, G, B gamma difference or “gray balance,” is important because the human eye is very sensitive to gray balance. The gray balance parameter indicates the relative balance, or imbalance, between the different color channels of a display device when producing RGB color combinations.
- FIG. 5 is a flow diagram illustrating a color profiling process as shown in FIG. 4 in greater detail. As shown in FIG. 5, for blackpoint determination,
color profile server 18 first may serve a web page for display device adjustment. The web page instructs the user to adjust the brightness and contrast of the display device. This step of display device adjustment is optional, but generally desirable in preparing the display device for blackpoint determination. As indicated byreference numeral 76,color profile server 18 may serve a web page containing several rows of dark elements such as bars, patches, characters, letters, numerals, and the like. - Instead of patches or bars, it may be desirable to display elements with alternative shapes such as numerals. Whereas the patches or bars may be generally rectangular, more complex shapes can be used to aid the human eye in resolving differences. Thus, numerals, letters, and other complex shapes, for example, engage the pattern recognition capabilities of the human eye and can result in heightened sensitivity to gray scale differences. When the human eye is called upon to perform pattern recognition, its sensitivity to color gradations between a given pattern and a surrounding area increase. The complex shape presents a longer boundary relative to simple shapes, and promotes an increased perimeter for contrast. Elements with complex shapes may be used in the blackpoint, coarse gamma, and fine gamma determinations to characterize the monitor.
- As an alternative to rows, the elements can be arranged in columns placed side-by-side across the web page. As a further alternative, each row or column may contain, instead of several elements, only one or a small number of elements. A larger number of elements in each given row may aid the user in resolving differences between elements in adjacent rows.
- The web page may instruct the user to set the brightness and contrast of the display device to maximum, as indicated by
reference numeral 78. The rows (or columns) of elements may be arranged in a series. The elements in each row preferably exhibit the same darkness or lightness. However, the elements in each row in the series differ in relative darkness or lightness relative to the elements in other adjacent rows. For example, the darkest row of elements could be situated at the bottom, with rows containing elements with progressively lighter shades being situated above in ascending order. As indicated byreference numeral 80, the web page instructs the user to reduce the brightness until the darkest row of elements is barely visible. At this point, the user may select “next” or some similar hypertext icon and proceed to the next step in the color profiling process, e.g., blackpoint determination for each of the red, blue, and green channels on an individual basis. - FIG. 6 illustrates a
web page 122 for use in display device adjustment in a color profiling process as shown in FIG. 5.Rows 124 of dark elements are displayed, with the elements each row having the same gray level value, but different gray level values from elements in adjacent rows. As an example,rows 124 of dark elements (shown as numerals in the example of FIG. 7) may be presented to the user with the following gray level values: 8, 16, 24, and 32. In other words, the rows of “zeros,” “ones,” “twos,” and “threes” may have gray levels of 8, 16, 24, and 32, respectively. As the rows of dark gray elements are displayed, the user is instructed to set brightness and contrast of the display device to maximum, using the analog or digital controls provided with the display device. The user is then further instructed to reduce the brightness of the display device until the row with the darkest (lowest gray level value) elements is barely visible, and then click “next” upon completion. This optional step of display device adjustment serves to prepare the monitor for the blackpoint determination carried out with respect to each color channel, as described below. - To carry out the blackpoint determination process for each color channel, several rows (or columns) of dark elements for each color channel may be displayed on successive web pages. Specifically, red channel, blue channel, and green channel web pages for channel-specific blackpoint determination can be served to the client in any order. In each case, the dark elements for a given color channel may be arranged in rows in ascending or descending order of relative lightness or darkness, as in
web page 122 of FIG. 6, which is served for display device adjustment. The rows provide a sequence of gray level gradations. - The bottom row for the red channel blackpoint determination web page, for example, may be a row of “zeros” having elements bearing the darkest shade (lowest gray value) of red among the elements shown on the web page. As with
web page 122, arrangement of the elements in rows or columns is for purposes of illustration. In some embodiments, display of a series of individual elements (rather than rows of elements) may suffice. - The row of darkest elements that is barely visible to the user will depend on the blackpoint for the respective channel of the display device. The rows of elements are displayed against a black, i.e., RGB=0, background. With some display devices, the user may be unable to see elements with intensity levels of 8, 16, or higher. The user is instructed to select the row of elements that is barely visible on the display device. This step determines the blackpoint, i.e., the visible “cut-off” point at which further decreases at which further decreases in the color channel value produce no further decreases in light emitted by the display device for that color channel. As an alternative, the user could be prompted to make the least visible row of elements vanish for a given color channel and then click on the remaining barely visible bar. In either case, the blackpoint can be estimated.
- FIG. 7 illustrates a
web page 128 for use in blackpoint determination in a color profiling process as shown in FIG. 5.Web page 128 may be substantially similar toweb page 122 of FIG. 6. For example,web page 128 may includerows 130 of shaded elements. Again, display of columns of elements or a series of elements may be sufficient for some applications. As shown in FIG. 7,web page 128 instructs the user to select the row of elements that is barely visible on the display device. As inweb page 122, therows 130 inweb page 128 may be arranged as rows of “zeros,” “ones,” “twos,” and “threes” having, for example, intensity levels of 8, 16, 24, and 32, respectively.Web page 128 in FIG. 7 represents the web page for red channel blackpoint determination, and includes rows of red elements set against a black background. - Upon selection of the row that is barely visible for the red channel, e.g., upon clicking on any element in the row, the user is automatically served a substantially identical web page containing rows of green elements set against a black background for purposes of determining the green channel blackpoint. In this manner, the user selects a visible row or element that most closely appears to match, or blend with, the black background. Following selection of a row of green elements that is barely visible, a substantially identical web page for blue channel blackpoint determination is served to the user and the user makes a similar selection. Thus, successive web pages governing blackpoint determination for each color channel can be served automatically following selection of a row for a preceding channel. Alternatively, the user may be prompted to click on a “next” icon or similar device. Serving successive web pages automatically following selection of an element may be desirable, of course, to reduce the overall number of clicks involved in the process.
- In the above manner, the user selects the row of elements that is barely visible for each color channel, and thereby provides an indication of the blackpoint for each color channel. FIG. 5 further illustrates the process. In particular, FIG. 5 shows the display of rows of dark red elements or characters (82), and selection of the row that is barely visible (84), and further illustrates the computation of the estimated blackpoint for the red channel based on the selected row (86). Similarly, for the green channel, a row of dark green characters is displayed (88), followed by selection of the row that is barely visible (90), and computation of an estimated blackpoint for the green channel based on the selected row (92). Finally, for the blue channel, a row of dark blue characters is displayed (94), followed by selection of the row that is barely visible (96), and computation of an estimated blackpoint for the blue channel based on the selected row (98).
- Following selection of the barely visible row of elements displayed on each successive web page,
client device 14 a-14 n transmits the result tocolor profile server 18. Alternatively, the results for all color channels can be transmitted at the same time following completion of the blackpoint determination for the last color channel.Color profile server 18 then may compute the estimated blackpoint for each channel, as indicated byreference numerals color imager server 16. -
- The variables dr, dg, and db are the digital input values normalized to 1.0. The parameters ko,r, ko,g, and ko,b, are the blackpoints and the parameters γr, γg, and γb are the gammas for the red, green, blue channels.
-
- This device value dt,r is determined by the user during the color profiling procedure as described, i.e., by selecting the darkest barely visible row of elements in the blackpoint determination web page for red. The value of Rt is empirically determined. For example for a calibrated display system in a dark room with ko,r=0.0 and γr=2.2, a red patch may be visible for dt,r=8/255 gray levels which implies Rt=(8/255)2.2.
-
- In a similar fashion, the values for ko,g and ko,b, can be determined.
- FIG. 8 is a flow diagram illustrating gamma and gray balance determination in a color profiling process as shown in FIG. 5. For determination of coarse gamma, one of the web pages served by
color profile server 18 displays a range of green elements, e.g., patches, against a dithered green background, as indicated byreference numeral 100. The coarse gamma determination web page can be served immediately and automatically following selection of a row of elements in the last blackpoint determination web page, or in response to selection of a “next” icon or similar device. - In one embodiment, the coarse gamma determination is limited to only the green color channel. Specifically, the coarse gamma determination is made using a series of green elements against a green dithered background. Green is the most dominant and intense phosphor among red, green, and blue, and is highest in contrast. Green also has the highest L*. Note also that green most closely matches the photopic V(λ) response of the eye. This approach to coarse gamma determination considers only the green color channel, and essentially ignores red and blue. In this manner, the coarse gamma measurement concentrates on the most dominant color channel and avoids errors that can arise to the red-blue imbalances that are highly prevalent in many display devices. Thus, the elements displayed for the coarse gamma determination may be green patches with different darkness or lightness values. Alternatively, a combined coarse gamma for all of the color channels may be determined as described in the above-referenced U.S. patent application Ser. No. 09/631,312.
- Upon display of the green patches, the user is instructed to select a patch that appears to most closely blend with the dithered background, as indicated by
reference numeral 102 in FIG. 8. The green patch “blends” with the dithered background in the sense that it appears to closely match the level of the background. An example of a range of green patches displayed against a green dithered background is shown in FIG. 9 and indicated byreference numeral 132. This range of green patches and the green dithered background can be displayed in a web page served bycolor profile server 18. Based on the selected green patch, which again may be selected by clicking on it with a pointing device,color profile server 18 computes a coarse gamma, as indicated byreference numeral 104 in FIG. 8. The coarse gamma determined in this step can be used as an estimate for the average gamma of R, G, and B via selection of a green patch from the set of green patches against the dithered green background. The dithered green background may be set at approximately 25% to 50%. Dithered backgrounds approaching approximately 33% may more closely match the actual midpoint of black to green transition for the display device, and may be preferred for typical display devices. - By alternating black and green at an appropriate frequency, a 25%, 33%, or 50% green background can be produced. For a CRT, turning on or off all of the pixels in a given horizontal line should produce more predictable output from display device to display device than modulating individual pixels to form vertical lines, due to the video bandwidth of the device. For flat panel devices, this is less of an issue. To accommodate clients using both CRT's and flat panel devices, however, generation of the dithered background by use of alternating horizontal lines is preferred.
- The center patch in the
range 132 of patches can be based on an average gamma of 2.0, since most monitors range from 1.6 to 2.5. The other green patches that surround the center patch may proceed in a sequence with relatively large steps, e.g., 8 gray levels apart from one another. Coarse gamma can be estimated using the equation: - G .33=0.333=[(d .33,g −k o,g)/(1.0−k o,g)]γ g
- where d.33,g is the gray level value (normalized to 1.0) of the selected patch that appears to most closely blend in with the background, ko,g is the previously determined blackpoint, G.33 is the relative intensity of the green channel (equal to ⅓), and γg is the green gamma. As an alternative to actually computing the coarse gamma, the green level value of the selected patch simply is carried forward for use in the fine gamma process. In this case, the value can eventually be discarded.
- After the coarse gamma estimate is obtained, fine gamma is estimated. Fine gamma is a refined or “fine-tuned” estimate for the average gamma of R, G, and B. Fine gamma can be determined by selection of another green patch from a set of green patches presented against a dithered green background. In this case, the center patch may be identical to the green patch selected by the user for determination of coarse gamma. Thus, the coarse gamma step “informs” the fine gamma step. In effect, the selected coarse gamma patch may serve as a starting point for the fine gamma determination. Specifically, the green patch selected in the coarse gamma determination can be used as the central patch for the fine gamma determination.
- A range of patches for determining fine gamma is illustrated in FIG. 10 and designated by
reference numeral 134. The patches in this range are in a sequence with smaller steps centered about the center green patch selected in the coarse gamma process. For example, the patches may be set at 4 green levels apart, in contrast to the 8 green levels used as the difference for the coarse gamma determination. In this manner, a narrower range is used to “fine-tune” the coarse gamma estimate, with the center of the range having been “learned” from the coarse gamma estimate. - As indicated by
reference numeral 106, a web page served bycolor profile server 18 displays the selected green patch from the coarse gamma estimate among a narrower range of green patches. The user then is instructed to select the green patch that most closely blends with the same dithered green background as used for coarse gamma, as indicated byreference numeral 108. Based on the selected patch,color profile server 18 computes a single fine RGB gamma, as indicated byreference numeral 110. Thus, the fine gamma is the overall gamma estimated for the RGB channels. Alternatively, as mentioned above, the RGB value of the selected patch can simply be stored for use bycolor image server 16 a-16 b in computing fine gamma and rendering color corrections. In any event, a refined estimate for gamma can be computed according to the equation: - G .33=333=[(d .33,g −k o,g)/(1.0−k o,g)]γ g
- where d.33,g is the green level value (normalized to 1.0) of the selected patch that blends in with the background, ko,g is the previously determined blackpoint, G.33 is the relative intensity of the green channel (equal to ⅓), and γg is the green gamma.
- To determine gray balance,
color profile server 18 serves a web page that displays a plurality of RGB gray patches. The RGB gray patches can be generated with the same value of green selected in the previous fine gamma step in conjunction with values of red and blue that are substantially equal to or systematically shifted from the previously selected value of green. The RGB patches can be displayed against a gray background which is dithered in the same manner as the green dithered background of the previous step (fine gamma), as indicated byreference numeral 112. Again, this step “learns” from the previous one, and forms part of a cascading series of color profiling steps (coarse gamma, fine gamma, and gray balance) that help narrow the search for the correct gamma. As indicated byreference numeral 114, the user is then instructed to select the gray patch that appears to most closely blend with the dithered background. Based on the selected gray patch, individual RGB gammas are computed, as indicated byreference numeral 116. Notably, the overall gray balance determination can be made with a single click of the user's pointing device. - Thus, in this gray balance process, the green intensity value selected in the fine gamma process is used to generate the gray patches that exhibit +/− (plus/minus) differences or “shifts” in red and blue about the value of the central gray patch derived from the gamma estimate. For example, the value of green selected in the fine gamma process can be displayed in the center of the range in conjunction with substantially identical values of red and blue. The gammas for red and blue are then fine tuned by the gray balance determination, which helps identify red-blue imbalance in the display device. Thus, the green gamma is “locked in” in the gray balance step, while the red and blue imbalance is determined. In other words, every patch in the gray balance array carries the same green value, but is modulated by different gradations of red and blue. This step eliminates one axis of variation, green, but permits identification of any imbalance between red and green or blue and green. This limits the range of choices to a more finely-tuned area, and aids the user in making a more accurate selection.
- The range of patches for the gray balance determination may be a two-dimensional array of patches with red-blue-shifted patches arranged around a central gray patch formed according to the gamma estimate from the fine gamma process. In other embodiments, the red channel could be used to determine the initial RGB gamma estimate, followed by a gray balance determination that resolves imbalance between green and red or blue and red.
- FIG. 11 illustrates an example of a two-
dimensional range 136 of gray patches arranged in a five-by-five matrix for use in the gray balance determination. Each patch represents a shift away from the central gray patch along either the blue axis, the red axis, or a combination of both, but preferably does not represent any further green shift. The user selects the patch that appears to most closely blend with the dithered gray background, which may be a 33% dithered background. The central patch can optionally be highlighted to indicate it is the preferred default choice. - The number of patches and the exact values of RGB for each patch can be quite flexible. For example, in the case of the image in FIG. 11, all patches can be selected to have identical values of L* as indicated by the estimated profile for the display based on phosphors, average gamma, and blackpoint. Patches adjacent to the center may differ by all permutations of +/−3 ΔE for a* and for b* as estimated from a Matrix TRC (tone reproduction curve) profile constructed from the above parameters.
- Patches around the outer perimeter of the grid array may differ from the center by +/−6 ΔE in R and B. Alternatively, for simplicity, one can elect to vary R and B only by +/− a fixed amount such as +/−5 gray levels and +/−10 gray levels. Preferably, all patches are relatively small deviations from the central patch in all directions of color space of approximately constant L*. This test will help determine in a sensitive manner whether there exists a significant difference in the gammas of R, G, and B, and thereby expose significant gray imbalance between R and B.
- The two-dimensional format of the patches shown in FIG. 11 may aid the user's selection of the correct patch. The patch from the previous step in the color profiling process, i.e., fine gamma, is placed at the center in this embodiment. Adjacent patches differ in gray level as the array extends outward such that the outer periphery of the array contains patches that are two gradations removed from the central patch. The array produces a visual “funnel” effect that, from experience, tends to direct the user toward the central patch as the starting point for matching with the background. The differences between patches in the two-dimensional array are more clear and dramatic than in a one-dimensional strip of patches. As the array extends outward, the shift becomes greater. Thus, the gradations are well pronounced and aid the user in picking the appropriate patch which, in many cases, will be the central patch selected in the previous step of the color profiling process.
- If the user selects the central patch, a single gamma value is used for the R, G, and B channels. If one of the other patches are selected, three separate gammas are calculated based on the equations:
- R .33=0.333=[(d .33,r −k o,r)/(1.0−k o,r)]γ r
- B .33=0.333=[(d .33,b −k o,b)(1.0−k o,b)]γ b
- where the subscripts for γ and d.33 indicate unique values for the R and B channels. The values for d.33 for each channel are given by the values of RGB of the particular patch selected in this gray balance step. These equations are combined with a set of phosphor values to generate accurate profiles for the client's display device, using equations well known in the art, and referred to as Matrix TRC formalism in the International Color Consortium (ICC) specification. Again, calculations can be performed by
color profile server 18 or by a color correction module associated withcolor image servers 16 a-16 n. - The process of selecting patches in the coarse gamma, fine gamma, and gray balance determination steps is advantageous because, in preferred embodiments, it requires no applications, applets, or other client-side scripts to be loaded at the client side. Rather, the user may simply select one of the patches displayed in a web page. In other embodiments, however, if applications, applets, or client-side scripts are used, it is conceivable that smooth slider bars, +/− arrows, and the like could be used to adjust the color of a single patch in real-time for comparison to the dithered background. In this manner, the user has the ability to precisely match a single patch to the background, rather than select from a finite set of patches the one that most closely matches. This technique of real-time adjustment also may be useful for non-networked approaches to color calibration and characterization. In this case, for blackpoints, gamma, and/or gray balance, the patch or element selected by the user may be a single adjustable patch in a condition in which the slider or other adjustment medium has adjusted its color to a level that is visually acceptable to the user, i.e., to a point at which the patch appears to match the dithered background.
- Based on the blackpoint, coarse gamma, fine gamma, and gray balance processes, a color profile for the display device is generated, as indicated by
reference numeral 118. Upon generation of the color profile, a color profiler cookie is created, as indicated byreference numeral 120. Information representative of the color profile is added to the color profiler cookie for future use. In particular, the information can be used to create a subscriber cookie for future interaction between theparticular client 14 a-14 n and the particular subscriber 22 a-22 n andcolor image server 16 a-16 n. Although the color profile is especially useful for characterizing display devices in a network, it also may be useful in a non-networked application. In particular, the color profiling process described herein may find ready use in the calibration and characterization of an individual display device for correction of content generated or obtained locally with the device, rather than across a network. - Advantageously, there is no need for the
client 14 a-14 n to provide information regarding the configuration of its display device. Very satisfactory results can occur using an average set of phosphor values based on published standards such as sRGB, Apple Macintosh RGB, and the like. If desired, further steps can be added, particularly in order to address the issue of phosphor values and white point. The color profiling process simply results in generation of a cookie that serves as a container and vehicle for passing information characterizing the color response of the display device associated withclient 14 a-14 n tocolor image server 16 a-16 n. Alternatively, the chromaticity information and white point can in some cases be obtained from the display utilizing communication protocols such as VESA and/or from the operating system of the computer. The usefulness of this invention will continue because, with current technology, the RGB blackpoints and gammas are difficult to maintain perfectly at the hardware level even with expensive electronic circuitry. - Ordinarily, all cookies visible to a particular domain are attached to each request from a browser application executed by a
client 14 a-14 n. For this reason, a typical browser limits each domain to a maximum of twenty cookies. To avoid consuming the allotment of cookies for a particular subscriber 22 a-22 n, all of the color correction information for aparticular client 14 a-14 n preferably is packed into a single profiler cookie and a single subscriber cookie. For example, a number of items can be packed into the value string of the subscriber cookie or the profiler cookie, as the case may be. In particular, each cookie should include the gamma values for R, G, and B. Each gamma value may be a value between 1.0 and about 3.0. In addition, the cookie may include the chromaticity values for black and white, e.g., expressed as a value between 0 and +1000.0. - An exemplary cookie may have the following items packed into its value string, each demarcated by a separator:
- (1) Cookie format version code—a numeric code, e.g., 1 to 3 bytes, plus separator.
- (2) Cookie installation date—the usual cookie-style timestamp (milliseconds after midnight of Jan. 1, 1970, GMT), e.g., 12 to 13 bytes, plus separator.
- (3) Unique profiler ID assigned to this color information when it is generated by the color correction sequence; a long integer, e.g., 4 bytes, plus separator (but possibly longer).
- (4) Gamma and blackpoint values for R, G, B—each a text representation of a floating-point value between 1.0 and about 3.0, retaining 4 decimal digits. The decimal point could be implied. Thus, the gamma values may take up 5 or 6 bytes plus a separator each, or three times that overall. Alternatively, the selected tint values chosen for R, G, and B can be indicated, enabling the gamma and blackpoint values to be calculated at a later time by a server upon upload of the cookie.
- (5) Chromaticity for Black and White—each a text representation of a floating-point value between 0 and +1000.0, retaining 4 significant digits. Thus, this may take up 6 or 7 bytes plus a separator each, or two times that overall.
- (6) Number of bits per color—two decimal digits: two bytes plus separator.
- (7) Display Device ID code—an alphanumeric code, which may be roughly 10 bytes plus separator.
- (8) Cookie Data Checksum—a long integer: 4 bytes.
- The example cookie described above has about 68 bytes plus 10 separators. The separator character should be chosen so that the string does not have to be “escaped”; the caret (A) is frequently used this way. Thus, the typical size for the value string may be about 80 bytes.
- FIG. 12 is an example of a
color image 184 transmitted to aclient 14 a-14 n in a system as shown in FIGS. 1 and 2. As shown in FIG. 12, theimage 184 may be presented on ascreen 182 on a display device associated with aclient 14 a-14 n. Acolor image server 16 a-16 n associated with a particular subscriber 22 a-22 b, such as “ABC Company,” deliversimage 184 to theclient 14 a-14 n upon request. For purposes of illustration,image 184 may be accompanied by alegend 186 that identifies the subscriber 22 a-22 n and a particular item being displayed. Also, an icon, button, or the like may accompanyimage 184 and indicate whether color correction has been applied bycolor image server 16 a-16 n, as indicated byreference numeral 188. In the example of FIG. 12, color correction has not been applied, e.g., because a subscriber cookie has not yet been generated for the particular subscriber 22 a-22 n. Another icon, button, or the like may be displayed to invite the user to profile its display device, as indicated byreference numeral 190. -
Elements element 190 provides a hypertext link to the URL associated withcolor profile server 18. Thus, when the user clicks onelement 190, pages are requested fromcolor profile server 18 for initiation of the color profiling process. If a profiler cookie already exists, however, it is sent byclient 14 a-14 n tocolor profile server 18. In that case, there is no need to repeat the color profiling process. Instead,color profile server 18 creates a subscriber cookie for the pertinent subscriber 22 a-22 n, and forwards it to the associatedcolor image server 16 a-16 n, either directly without user intervention or indirectly with user approval as previously described. - FIG. 13 is block diagram illustrating transmission of color correction information in a system as shown in FIGS. 1 and 2. In particular, FIG. 13 illustrates a situation in which subscriber cookies have already been created for
color image servers individual client 196. In this case, upon accessing a web page from asubscriber server 12 a-12 n,client 196 requests images fromcolor image server 194. When requesting images from another subscriber 22 a-22 n,client 196 requests images fromcolor image server 198.Color image server 194 incorporates both acolor correction module 200 and anarchive 202 of color images. Similarly,color image server 198 includes acolor correction module 204 and an archive ofcolor images 206. - When
client 196 sends an image request tocolor image server 194, it sends along a color profile cookie, i.e., a subscriber cookie, as indicated byline 208. Likewise, as indicated byline 210,client 196 sends a subscriber cookie tocolor image server 198 when requesting an image. In each case, the subscriber cookie contains a color profile that provides color correction information for use by the respectivecolor correction module image archives color images server color correction module client 196 receives color corrected images, as indicated byreference numerals - The manner in which color correction modules make use of the color profiles contained in the subscriber cookies will now be described. The foregoing discussion associated with FIGS.4-11 above has utilized simplified one dimensional formulas to explain the relevance of blackpoint, average gamma, and adjusted gammas for RGB to account for gray balance. In the embodiment described with reference to FIGS. 4-11, blackpoints for each color channel are estimated based on red, green, and blue elements selected by a user associated with a
respective client 14 a-14 n. Thus, the output of the color profiling process is a blackpoint RGB value and a gamma, or individual RGB gammas. Now we assume that these values have been determined in the manner described above. The complete description of the display device behavior can be given by the following equation which relates RGB->XYZ: - The variables dr, dg, and db are the digital input values normalized to 1.0. The parameters ko,r, ko,g, and ko,b, are the blackpoints for the red, green, and blue channels, and the parameters γr, γg, and γb are the gammas for the red, green, blue channels. Thus, the gamma and blackpoint information contained in the subscriber cookie for a respective display device can be used in the above equations to produce, in effect, a destination device profile. The destination device profile, with a source profile previously computed for the requested image, can be used to perform a transformation of the image data sufficient to produce calibrated output on the display device.
- The above approach is different than other attempts to characterize display devices such as equation 21 in Bems, “CRT Colorimetry. Part I: Theory and Practice.” In most characterizations, the “k” parameters are used to describe black offset rather than blackpoint. Black offset refers to the non-zero intensity measured or perceived from a display for RGB=0. In our experience, the contrast/brightness adjustment procedure used in a color profiling process in accordance with embodiments of this invention minimizes the effect of this phenomenon. However, non-zero blackpoints are very possible even after the contrast/brightness adjustment, and therefore should be taken into account.
- This profile description can either be used in this format or converted to formats such as those specified by the ICC. This format is also known as the Matrix TRC format, and utilizes a generic lookup table for the expressions above for R, G, and B rather than an equation combined with a matrix similar to above. The above information, e.g., gammas, blackpoints, and the like, can be stored in a cookie on a computer associated with a
client 14 a-14 n. Alternatively, the individual data which are the RGB values of the patches selected by the user can be stored in the cookie, which can permit improved profile technology to be employed at a later date utilizing the same input information. - To implement a system as described herein with an existing archive of images and HTML codebase for a particular subscriber22 a-22 b, the existing
subscriber server 12 a-12 n is modified to replace existing image file references indicated in HTML pages with similar references to a pertinentcolor image server 16 a-16 n equipped with a color correction module. For example, an existing subscriber image file reference called: - https://SubscriberName.com/images/ImageNamejpg could be replaced with:
- https://correction. SubscriberName.com/images/ImageName.jpg.
- These modified references in the HTML page then issue a command to the
color image server 16 a-16 n to serve the requested image. When thecolor image server 16 a-16 n receives the command, it also receives the subscriber cookie, if one exists, and applies the information contained in the cookie to perform color correction. Thecolor image server 16 a-16 n then reads the pertinent image file, creates a unique display profile utilizing the display parameters stored in the subscriber cookie, and converts the image from source to destination before sending it to the client's browser. - All images stored on the
subscriber server 12 a-12 n may have a corresponding copy file of the same name residing on the subscribercolor image server 16 a-16 n. Thecolor image server 16 a-16 n may access this database of image files to read, convert, and send images referenced by the HTML page sent to theclient 14 a-14 n. According to one embodiment,color image server 16 a-16 n may use a very simple and quick technique for color management. In particular, all images on thecolor image server 16 a-16 n preferably have a predetermined RGB color space. This typically means that original images are converted from the color space of corresponding source devices, e.g., such as scanners, digital cameras, and the like, to the standard color space determined by the subscriber 22 a-22 n. Good examples of standard RGB color spaces are ColorMatch RGB, which has a color temperature for the “virtual display” of D50. Other color spaces such as Adobe RGB have an excellent gamut, but have a color temperature of D65. When an image on an HTML page sent to theclient 14 a-14 n is referenced via thecolor image server 16 a-16 n associated with asubscriber server 12 a-12 n such as: - correction.SubscriberName.com/images/ImageName.jpg
-
- Note that the matrices above can be concatenated into a single matrix for increased processing speed.
- FIG. 14 is a block diagram illustrating an alternative architecture for a
system 214 for improving color image display accuracy in a computer network.System 214 conforms substantially to the system shown in FIG. 2, except that all images for the subscribers are stored at a centralcolor image server 16.Color profiling server 18 may reside or be integrated withcolor image server 16 in the embodiment of FIG. 14. In this case,color profiling server 18 provides web pages for guidance of a color profiling process as described herein.Color image server 16 orcolor profile server 18 may include a database server for storage of individual color profiles associated withclients 14 a-14 n. When aclient 14 a-14 n requests an image tagged in the code sent by one ofsubscriber servers 12 a-12 n, it is directed to the centralcolor image server 16. Thecolor image server 16 may use a client ID sent from the client to retrieve the appropriate color profile and apply it to modify the requested color image using techniques as described herein for color correction. In this manner,color image server 16 provides color corrected images without the need for transfer of cookies and the like betweenclients 14 a-14 n and the color image server. - A number of embodiments of the present invention have been described. Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the invention. Accordingly, other embodiments are within the scope of the following claims.
Claims (36)
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/778,484 US20030091229A1 (en) | 2000-03-31 | 2001-02-07 | Color image display accuracy using comparison of complex shapes to reference background |
EP01952285A EP1358630A1 (en) | 2001-02-07 | 2001-06-28 | Color image display accuracy using comparison of complex shapes to reference background |
PCT/US2001/020613 WO2002063563A1 (en) | 2001-02-07 | 2001-06-28 | Color image display accuracy using comparison of complex shapes to reference background |
JP2002563431A JP2004530147A (en) | 2001-02-07 | 2001-06-28 | Color image display accuracy using comparison between complex shapes and reference background |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US19372500P | 2000-03-31 | 2000-03-31 | |
US24689000P | 2000-11-08 | 2000-11-08 | |
US09/778,484 US20030091229A1 (en) | 2000-03-31 | 2001-02-07 | Color image display accuracy using comparison of complex shapes to reference background |
Publications (1)
Publication Number | Publication Date |
---|---|
US20030091229A1 true US20030091229A1 (en) | 2003-05-15 |
Family
ID=25113493
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/778,484 Abandoned US20030091229A1 (en) | 2000-03-31 | 2001-02-07 | Color image display accuracy using comparison of complex shapes to reference background |
Country Status (4)
Country | Link |
---|---|
US (1) | US20030091229A1 (en) |
EP (1) | EP1358630A1 (en) |
JP (1) | JP2004530147A (en) |
WO (1) | WO2002063563A1 (en) |
Cited By (26)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20010039567A1 (en) * | 2000-04-07 | 2001-11-08 | Baker Tamara C. | Method and apparatus for distributing color corrected images across a network using distributed caching |
US20020003903A1 (en) * | 1998-11-13 | 2002-01-10 | Engeldrum Peter G. | Method and system for fast image correction |
US20020126135A1 (en) * | 1998-10-19 | 2002-09-12 | Keith Ball | Image sharing for instant messaging |
US20020129063A1 (en) * | 2001-03-09 | 2002-09-12 | Kosak Donald M. | Serving content to a client |
US20020180780A1 (en) * | 2001-04-03 | 2002-12-05 | Fuji Photo Film Co., Ltd. | Image data providing apparatus, and image data providing program storage medium |
US20030090494A1 (en) * | 2001-11-12 | 2003-05-15 | Keizo Ohta | Image processing apparatus and image processing program |
US7092008B1 (en) | 1998-11-13 | 2006-08-15 | Lightsurf, Inc. | Remote color characterization for delivery of high fidelity images |
US20060250412A1 (en) * | 2002-03-29 | 2006-11-09 | Kok Chen | Method and apparatus for improved color correction |
US7339595B2 (en) | 1998-10-19 | 2008-03-04 | Lightsurf Technologies, Inc. | Method and system for improved internet color |
US20090059257A1 (en) * | 2007-08-31 | 2009-03-05 | Brother Kogyo Kabushiki Kaisha | Image processing device capable of preventing needless printing |
US20090060364A1 (en) * | 2007-08-31 | 2009-03-05 | Brother Kogyo Kabushiki Kaisha | Image processor for converting image by using image retrieved based on keyword |
US20090128587A1 (en) * | 2007-11-19 | 2009-05-21 | Olympus Corporation | Color reproduction system, color reproduction device, color reproduction method, and computer-readable recording medium recorded with color reproduction program |
US20090244564A1 (en) * | 2007-08-31 | 2009-10-01 | Brother Kogyo Kabushiki Kaisha | Image processing device extracting desired region to be used as model for image correction |
US20090267960A1 (en) * | 2008-04-24 | 2009-10-29 | International Business Machines Corporation | Color Modification of Objects in a Virtual Universe |
US20090267950A1 (en) * | 2008-04-24 | 2009-10-29 | International Business Machines Corporation | Fixed path transitions |
US20090296114A1 (en) * | 2008-05-27 | 2009-12-03 | Xerox Corporation | Color management methods and systems to adaptively tune colors for image marking devices |
US20100005423A1 (en) * | 2008-07-01 | 2010-01-07 | International Business Machines Corporation | Color Modifications of Objects in a Virtual Universe Based on User Display Settings |
US20100001993A1 (en) * | 2008-07-07 | 2010-01-07 | International Business Machines Corporation | Geometric and texture modifications of objects in a virtual universe based on real world user characteristics |
US8094343B2 (en) | 2007-08-31 | 2012-01-10 | Brother Kogyo Kabushiki Kaisha | Image processor |
US8159716B2 (en) | 2007-08-31 | 2012-04-17 | Brother Kogyo Kabushiki Kaisha | Image processing device performing image correction by using a plurality of sample images |
US20120098945A1 (en) * | 2010-10-26 | 2012-04-26 | Verizon Patent And Licensing, Inc. | Methods and Systems for Presenting Adjunct Content During a Presentation of a Media Content Instance |
US8174731B2 (en) | 2007-08-31 | 2012-05-08 | Brother Kogyo Kabushiki Kaisha | Image processing device outputting image for selecting sample image for image correction |
US8458603B2 (en) | 2009-01-14 | 2013-06-04 | International Business Machines Corporation | Contextual templates for modifying objects in a virtual universe |
US9265458B2 (en) | 2012-12-04 | 2016-02-23 | Sync-Think, Inc. | Application of smooth pursuit cognitive testing paradigms to clinical drug development |
US9380976B2 (en) | 2013-03-11 | 2016-07-05 | Sync-Think, Inc. | Optical neuroinformatics |
US11551637B2 (en) * | 2020-01-22 | 2023-01-10 | Canon Kabushiki Kaisha | Electronic device and control method thereof |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20020161803A1 (en) * | 2001-03-15 | 2002-10-31 | Imation Corp. | Web page color accuracy |
Citations (31)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4409614A (en) * | 1978-10-10 | 1983-10-11 | Helmut Eichler | Method for the reproduction of originals which, with respect to their color content, are scanned according to a tristimulus method |
US4921334A (en) * | 1988-07-18 | 1990-05-01 | General Electric Company | Matrix liquid crystal display with extended gray scale |
US4984072A (en) * | 1987-08-03 | 1991-01-08 | American Film Technologies, Inc. | System and method for color image enhancement |
US5381349A (en) * | 1993-06-29 | 1995-01-10 | Hewlett-Packard Company | System for calibrating a color display to enable color-matching |
US5400153A (en) * | 1991-07-26 | 1995-03-21 | Oce-Nederland, B.V. | System and method of determining a reference value for the intensity associated with a color indication variable obtained by scanning an original with a color scanning unit |
US5512961A (en) * | 1993-03-24 | 1996-04-30 | Apple Computer, Inc. | Method and system of achieving accurate white point setting of a CRT display |
US5553200A (en) * | 1995-03-03 | 1996-09-03 | Electronics For Imaging, Inc. | Method and apparatus for providing bit-rate reduction and reconstruction of image data using dither arrays |
US5583666A (en) * | 1993-02-12 | 1996-12-10 | Eastman Kodak Company | Method for cross-device color calibration and enhancement using explicit constraints |
US5586236A (en) * | 1993-08-11 | 1996-12-17 | Object Technology Licensing Corp. | Universal color look up table and method of generation |
US5638117A (en) * | 1994-11-14 | 1997-06-10 | Sonnetech, Ltd. | Interactive method and system for color characterization and calibration of display device |
US5781206A (en) * | 1995-05-01 | 1998-07-14 | Minnesota Mining And Manufacturing Company | Apparatus and method for recalibrating a multi-color imaging system |
US5854851A (en) * | 1993-08-13 | 1998-12-29 | Sophis View Technologies Ltd. | System and method for diagnosis of living tissue diseases using digital image processing |
US5874988A (en) * | 1996-07-08 | 1999-02-23 | Da Vinci Systems, Inc. | System and methods for automated color correction |
US5910796A (en) * | 1996-05-20 | 1999-06-08 | Ricoh Corporation | Monitor gamma determination and correction |
US6008836A (en) * | 1996-06-03 | 1999-12-28 | Webtv Networks, Inc. | Method and apparatus for adjusting television display control using a browser |
US6043894A (en) * | 1998-07-10 | 2000-03-28 | Gretamacbeth Llc | Method for maintaining uniformity among color measuring instruments |
US6043909A (en) * | 1996-02-26 | 2000-03-28 | Imagicolor Corporation | System for distributing and controlling color reproduction at multiple sites |
US6084564A (en) * | 1996-05-16 | 2000-07-04 | Brother Kogyo Kabushiki Kaisha | Apparatus for determining a black point on a display unit and method of performing the same |
US6091518A (en) * | 1996-06-28 | 2000-07-18 | Fuji Xerox Co., Ltd. | Image transfer apparatus, image transmitter, profile information transmitter, image receiver/reproducer, storage medium, image receiver, program transmitter, and image color correction apparatus |
US6185005B1 (en) * | 1998-04-30 | 2001-02-06 | Hitachi Koki Imaging Solutions, Inc. | Half tone image enhancement for printers |
US6198545B1 (en) * | 1994-03-30 | 2001-03-06 | Victor Ostromoukhov | Method and apparatus for generating halftone images by evolutionary screen dot contours |
US6243070B1 (en) * | 1998-10-07 | 2001-06-05 | Microsoft Corporation | Method and apparatus for detecting and reducing color artifacts in images |
US20010014174A1 (en) * | 1996-11-05 | 2001-08-16 | Nobuo Yamamoto | Print preview and setting background color in accordance with a gamma value, color temperature and illumination types |
US20010043376A1 (en) * | 1997-05-27 | 2001-11-22 | Shuichi Kumada | Image processing method, image processing apparatus and computer readable memory |
US20010053248A1 (en) * | 1996-02-15 | 2001-12-20 | Mitsuru Maeda | Image processing apparatus and method and medium |
US6342896B1 (en) * | 1999-03-19 | 2002-01-29 | Microsoft Corporation | Methods and apparatus for efficiently implementing and modifying foreground and background color selections |
US20020015044A1 (en) * | 2000-03-31 | 2002-02-07 | Imation Corp. | Color image display accuracy using green-locked gray balance estimate |
US6349300B1 (en) * | 1999-04-16 | 2002-02-19 | General Electric Company | Method and system for selecting product colors |
US6439722B1 (en) * | 1998-12-01 | 2002-08-27 | Gretagmacbeth | System and method for synchronizing the appearance of color images |
US6476824B1 (en) * | 1998-08-05 | 2002-11-05 | Mitsubishi Denki Kabushiki Kaisha | Luminance resolution enhancement circuit and display apparatus using same |
US6711287B1 (en) * | 1998-12-21 | 2004-03-23 | Ricoh Company, Ltd. | Image-feature extraction method and computer-readable record medium with a program for making a computer execute steps of the method recorded therein |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5459678A (en) * | 1992-07-02 | 1995-10-17 | Feasey; Michael F. | Method and calibration apparatus for calibrating computer monitors used in the printing and textile industries |
JPH07311839A (en) * | 1994-05-18 | 1995-11-28 | Ricoh Co Ltd | Information processing system |
JP2000083123A (en) * | 1998-09-03 | 2000-03-21 | Canon Inc | Image forming device, image transfer method and storage medium |
-
2001
- 2001-02-07 US US09/778,484 patent/US20030091229A1/en not_active Abandoned
- 2001-06-28 JP JP2002563431A patent/JP2004530147A/en active Pending
- 2001-06-28 WO PCT/US2001/020613 patent/WO2002063563A1/en not_active Application Discontinuation
- 2001-06-28 EP EP01952285A patent/EP1358630A1/en not_active Ceased
Patent Citations (34)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4409614A (en) * | 1978-10-10 | 1983-10-11 | Helmut Eichler | Method for the reproduction of originals which, with respect to their color content, are scanned according to a tristimulus method |
US4984072A (en) * | 1987-08-03 | 1991-01-08 | American Film Technologies, Inc. | System and method for color image enhancement |
US4921334A (en) * | 1988-07-18 | 1990-05-01 | General Electric Company | Matrix liquid crystal display with extended gray scale |
US5400153A (en) * | 1991-07-26 | 1995-03-21 | Oce-Nederland, B.V. | System and method of determining a reference value for the intensity associated with a color indication variable obtained by scanning an original with a color scanning unit |
US5583666A (en) * | 1993-02-12 | 1996-12-10 | Eastman Kodak Company | Method for cross-device color calibration and enhancement using explicit constraints |
US5512961A (en) * | 1993-03-24 | 1996-04-30 | Apple Computer, Inc. | Method and system of achieving accurate white point setting of a CRT display |
US5381349A (en) * | 1993-06-29 | 1995-01-10 | Hewlett-Packard Company | System for calibrating a color display to enable color-matching |
US5586236A (en) * | 1993-08-11 | 1996-12-17 | Object Technology Licensing Corp. | Universal color look up table and method of generation |
US5854851A (en) * | 1993-08-13 | 1998-12-29 | Sophis View Technologies Ltd. | System and method for diagnosis of living tissue diseases using digital image processing |
US6198545B1 (en) * | 1994-03-30 | 2001-03-06 | Victor Ostromoukhov | Method and apparatus for generating halftone images by evolutionary screen dot contours |
US5638117A (en) * | 1994-11-14 | 1997-06-10 | Sonnetech, Ltd. | Interactive method and system for color characterization and calibration of display device |
US5553200A (en) * | 1995-03-03 | 1996-09-03 | Electronics For Imaging, Inc. | Method and apparatus for providing bit-rate reduction and reconstruction of image data using dither arrays |
US6027201A (en) * | 1995-05-01 | 2000-02-22 | Minnesota Mining And Manufacturing Company | Recalibrating a multi-color imaging system |
US5877787A (en) * | 1995-05-01 | 1999-03-02 | Minnesota Mining And Manufacturing Company | Apparatus for recalibrating a multi-color imaging system |
US5781206A (en) * | 1995-05-01 | 1998-07-14 | Minnesota Mining And Manufacturing Company | Apparatus and method for recalibrating a multi-color imaging system |
US20010053248A1 (en) * | 1996-02-15 | 2001-12-20 | Mitsuru Maeda | Image processing apparatus and method and medium |
US6043909A (en) * | 1996-02-26 | 2000-03-28 | Imagicolor Corporation | System for distributing and controlling color reproduction at multiple sites |
US6084564A (en) * | 1996-05-16 | 2000-07-04 | Brother Kogyo Kabushiki Kaisha | Apparatus for determining a black point on a display unit and method of performing the same |
US5910796A (en) * | 1996-05-20 | 1999-06-08 | Ricoh Corporation | Monitor gamma determination and correction |
US6008836A (en) * | 1996-06-03 | 1999-12-28 | Webtv Networks, Inc. | Method and apparatus for adjusting television display control using a browser |
US6091518A (en) * | 1996-06-28 | 2000-07-18 | Fuji Xerox Co., Ltd. | Image transfer apparatus, image transmitter, profile information transmitter, image receiver/reproducer, storage medium, image receiver, program transmitter, and image color correction apparatus |
US5874988A (en) * | 1996-07-08 | 1999-02-23 | Da Vinci Systems, Inc. | System and methods for automated color correction |
US20010014174A1 (en) * | 1996-11-05 | 2001-08-16 | Nobuo Yamamoto | Print preview and setting background color in accordance with a gamma value, color temperature and illumination types |
US6343147B2 (en) * | 1996-11-05 | 2002-01-29 | Canon Kabushiki Kaisha | Print preview and setting background color in accordance with a gamma value, color temperature and illumination types |
US20010043376A1 (en) * | 1997-05-27 | 2001-11-22 | Shuichi Kumada | Image processing method, image processing apparatus and computer readable memory |
US6185005B1 (en) * | 1998-04-30 | 2001-02-06 | Hitachi Koki Imaging Solutions, Inc. | Half tone image enhancement for printers |
US6043894A (en) * | 1998-07-10 | 2000-03-28 | Gretamacbeth Llc | Method for maintaining uniformity among color measuring instruments |
US6476824B1 (en) * | 1998-08-05 | 2002-11-05 | Mitsubishi Denki Kabushiki Kaisha | Luminance resolution enhancement circuit and display apparatus using same |
US6243070B1 (en) * | 1998-10-07 | 2001-06-05 | Microsoft Corporation | Method and apparatus for detecting and reducing color artifacts in images |
US6439722B1 (en) * | 1998-12-01 | 2002-08-27 | Gretagmacbeth | System and method for synchronizing the appearance of color images |
US6711287B1 (en) * | 1998-12-21 | 2004-03-23 | Ricoh Company, Ltd. | Image-feature extraction method and computer-readable record medium with a program for making a computer execute steps of the method recorded therein |
US6342896B1 (en) * | 1999-03-19 | 2002-01-29 | Microsoft Corporation | Methods and apparatus for efficiently implementing and modifying foreground and background color selections |
US6349300B1 (en) * | 1999-04-16 | 2002-02-19 | General Electric Company | Method and system for selecting product colors |
US20020015044A1 (en) * | 2000-03-31 | 2002-02-07 | Imation Corp. | Color image display accuracy using green-locked gray balance estimate |
Cited By (46)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7339595B2 (en) | 1998-10-19 | 2008-03-04 | Lightsurf Technologies, Inc. | Method and system for improved internet color |
US8345060B2 (en) | 1998-10-19 | 2013-01-01 | Verisign, Inc. | Method and system for improved internet color |
US20020126135A1 (en) * | 1998-10-19 | 2002-09-12 | Keith Ball | Image sharing for instant messaging |
US7177466B1 (en) * | 1998-11-13 | 2007-02-13 | Lightsurf Technologies, Inc. | System and method for providing high fidelity color images |
US7092008B1 (en) | 1998-11-13 | 2006-08-15 | Lightsurf, Inc. | Remote color characterization for delivery of high fidelity images |
US20020003903A1 (en) * | 1998-11-13 | 2002-01-10 | Engeldrum Peter G. | Method and system for fast image correction |
US7839415B2 (en) | 1998-11-13 | 2010-11-23 | Verisign, Inc. | Method and system for improved internet color |
US6963668B2 (en) | 1998-11-13 | 2005-11-08 | Lightsurf Technologies, Inc. | Method and system for fast image correction |
US20080208967A1 (en) * | 1998-11-13 | 2008-08-28 | Hilliard William J | Method and System for Improved Internet Color |
US6895113B2 (en) | 2000-04-07 | 2005-05-17 | Lightsurf, Inc. | Method and apparatus for distributing color corrected images across a network using distributed caching |
US20010039567A1 (en) * | 2000-04-07 | 2001-11-08 | Baker Tamara C. | Method and apparatus for distributing color corrected images across a network using distributed caching |
US7228493B2 (en) * | 2001-03-09 | 2007-06-05 | Lycos, Inc. | Serving content to a client |
US20020129063A1 (en) * | 2001-03-09 | 2002-09-12 | Kosak Donald M. | Serving content to a client |
US20020180780A1 (en) * | 2001-04-03 | 2002-12-05 | Fuji Photo Film Co., Ltd. | Image data providing apparatus, and image data providing program storage medium |
US20030090494A1 (en) * | 2001-11-12 | 2003-05-15 | Keizo Ohta | Image processing apparatus and image processing program |
US7050066B2 (en) * | 2001-11-12 | 2006-05-23 | Nintendo Co., Ltd. | Image processing apparatus and image processing program |
US20060250412A1 (en) * | 2002-03-29 | 2006-11-09 | Kok Chen | Method and apparatus for improved color correction |
US8587603B2 (en) * | 2002-03-29 | 2013-11-19 | Apple Inc. | Method and apparatus for improved color correction |
US8094343B2 (en) | 2007-08-31 | 2012-01-10 | Brother Kogyo Kabushiki Kaisha | Image processor |
US20090059257A1 (en) * | 2007-08-31 | 2009-03-05 | Brother Kogyo Kabushiki Kaisha | Image processing device capable of preventing needless printing |
US8390905B2 (en) | 2007-08-31 | 2013-03-05 | Brother Kogyo Kabushiki Kaisha | Image processing device extracting desired region to be used as model for image correction |
US8311323B2 (en) * | 2007-08-31 | 2012-11-13 | Brother Kogyo Kabushiki Kaisha | Image processor for converting image by using image retrieved based on keyword |
US20090060364A1 (en) * | 2007-08-31 | 2009-03-05 | Brother Kogyo Kabushiki Kaisha | Image processor for converting image by using image retrieved based on keyword |
US20090244564A1 (en) * | 2007-08-31 | 2009-10-01 | Brother Kogyo Kabushiki Kaisha | Image processing device extracting desired region to be used as model for image correction |
US8159716B2 (en) | 2007-08-31 | 2012-04-17 | Brother Kogyo Kabushiki Kaisha | Image processing device performing image correction by using a plurality of sample images |
US8284417B2 (en) | 2007-08-31 | 2012-10-09 | Brother Kogyo Kabushiki Kaisha | Image processing device capable of preventing needless printing |
US8174731B2 (en) | 2007-08-31 | 2012-05-08 | Brother Kogyo Kabushiki Kaisha | Image processing device outputting image for selecting sample image for image correction |
US20090128587A1 (en) * | 2007-11-19 | 2009-05-21 | Olympus Corporation | Color reproduction system, color reproduction device, color reproduction method, and computer-readable recording medium recorded with color reproduction program |
US8237732B2 (en) * | 2007-11-19 | 2012-08-07 | Olympus Corporation | Color reproduction system, color reproduction device, color reproduction method, and computer-readable recording medium recorded with color reproduction program |
US20090267960A1 (en) * | 2008-04-24 | 2009-10-29 | International Business Machines Corporation | Color Modification of Objects in a Virtual Universe |
US8466931B2 (en) | 2008-04-24 | 2013-06-18 | International Business Machines Corporation | Color modification of objects in a virtual universe |
US20090267950A1 (en) * | 2008-04-24 | 2009-10-29 | International Business Machines Corporation | Fixed path transitions |
US20090296114A1 (en) * | 2008-05-27 | 2009-12-03 | Xerox Corporation | Color management methods and systems to adaptively tune colors for image marking devices |
US8314979B2 (en) * | 2008-05-27 | 2012-11-20 | Xerox Corporation | Color management methods and systems to adaptively tune colors for image marking devices |
US20100005423A1 (en) * | 2008-07-01 | 2010-01-07 | International Business Machines Corporation | Color Modifications of Objects in a Virtual Universe Based on User Display Settings |
US8990705B2 (en) * | 2008-07-01 | 2015-03-24 | International Business Machines Corporation | Color modifications of objects in a virtual universe based on user display settings |
US9235319B2 (en) | 2008-07-07 | 2016-01-12 | International Business Machines Corporation | Geometric and texture modifications of objects in a virtual universe based on real world user characteristics |
US8471843B2 (en) | 2008-07-07 | 2013-06-25 | International Business Machines Corporation | Geometric and texture modifications of objects in a virtual universe based on real world user characteristics |
US20100001993A1 (en) * | 2008-07-07 | 2010-01-07 | International Business Machines Corporation | Geometric and texture modifications of objects in a virtual universe based on real world user characteristics |
US8458603B2 (en) | 2009-01-14 | 2013-06-04 | International Business Machines Corporation | Contextual templates for modifying objects in a virtual universe |
US8760496B2 (en) * | 2010-10-26 | 2014-06-24 | Verizon Patent And Licensing Inc. | Methods and systems for presenting adjunct content during a presentation of a media content instance |
US9088789B2 (en) | 2010-10-26 | 2015-07-21 | Verizon Patent And Licensing Inc. | Methods and systems for presenting adjunct content during a presentation of a media content instance |
US20120098945A1 (en) * | 2010-10-26 | 2012-04-26 | Verizon Patent And Licensing, Inc. | Methods and Systems for Presenting Adjunct Content During a Presentation of a Media Content Instance |
US9265458B2 (en) | 2012-12-04 | 2016-02-23 | Sync-Think, Inc. | Application of smooth pursuit cognitive testing paradigms to clinical drug development |
US9380976B2 (en) | 2013-03-11 | 2016-07-05 | Sync-Think, Inc. | Optical neuroinformatics |
US11551637B2 (en) * | 2020-01-22 | 2023-01-10 | Canon Kabushiki Kaisha | Electronic device and control method thereof |
Also Published As
Publication number | Publication date |
---|---|
EP1358630A1 (en) | 2003-11-05 |
JP2004530147A (en) | 2004-09-30 |
WO2002063563A1 (en) | 2002-08-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20030091229A1 (en) | Color image display accuracy using comparison of complex shapes to reference background | |
US20020165881A1 (en) | Web page color accuracy using color-customized style sheets | |
US7119760B2 (en) | Color image display accuracy using green-limited gamma estimate | |
US20020169805A1 (en) | Web page color accuracy with image supervision | |
US20020161803A1 (en) | Web page color accuracy | |
US20020161659A1 (en) | Color image display accuracy for display devices on a network | |
US20020080147A1 (en) | Color image display accuracy using comparison of colored objects to dithered background | |
US6847376B2 (en) | Method and system for characterizing color display monitor output | |
US7664864B2 (en) | Meta content distribution network | |
US7339595B2 (en) | Method and system for improved internet color | |
EP1133722B1 (en) | Method for display with colour fidelity of images transmitted in a network | |
US20020015044A1 (en) | Color image display accuracy using green-locked gray balance estimate | |
US7092008B1 (en) | Remote color characterization for delivery of high fidelity images | |
EP1269416A1 (en) | Color accuracy across a computer network | |
EP2273486A2 (en) | Method and system for characterizing color display monitor output |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: IMATION CORP., MINNESOTA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:EDGE, CHRISTOPHER J.;FISCHER, TIMOTHY A.;REEL/FRAME:011583/0778 Effective date: 20010206 |
|
AS | Assignment |
Owner name: KODAK POLYCHROME GRAPHICS, CONNECTICUT Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:IMATION CORP.;REEL/FRAME:013063/0150 Effective date: 20020906 |
|
AS | Assignment |
Owner name: EASTMAN KODAK COMPANY,NEW YORK Free format text: MERGER;ASSIGNOR:KPG HOLDING COMPANY INC. (FORMERLY KODAK POLYCHROME GRAPHICS LLC);REEL/FRAME:018096/0117 Effective date: 20060619 Owner name: EASTMAN KODAK COMPANY, NEW YORK Free format text: MERGER;ASSIGNOR:KPG HOLDING COMPANY INC. (FORMERLY KODAK POLYCHROME GRAPHICS LLC);REEL/FRAME:018096/0117 Effective date: 20060619 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |