Download Srgb Color Profile Mac

SRGB Appearance profile. An sRGB Appearance profile has been developed, and has been tested internally and externally. This profile is a v4 replacement for commonly used sRGB v2 profiles. It gives better results in workflows that implement the ICC v4 specification, and is intended to be used in combination with other ICC v4 profiles. The Internet means an sRGB color space. The same goes for digital download deliveries to clients. If you provide digital images to your clients as part of your service, you should use the sRGB color profile. So many applications don’t actually read the color profile that is embedded in an image and just assume it is sRGB.

  1. Download Srgb Color Profile Mac Os
  2. Download Srgb Profile
  3. Download Srgb Color Profile Mac Os

Table of Contents

  • Basic Examples
  • Conversion Errors

Quick Overview

This article provides details on how macOS color space conversion affects the values displayed in color meter utilities. Let's start by listing common mistakes made by developers:

A color can be identified by it's red, green, and blue values.

False. A color needs both coordinates and a color space (such as “my monitor's space” or “sRGB”) to be identified. While many web developers would say #ff0000 is red, it may be bright purple or green in a contrived space.

CSS colors correspond to my monitor's color space.

False. Per the CSS Color Module standard, colors are specified in the sRGB color space. Historically, however, browsers haven't color-corrected CSS colors. Safari 9 correctly treats CSS colors as sRGB and Chrome has an open issue to fix this.

Cocoa's “Device RGB color space” corresponds to my monitor's color space.

False. Starting in Mountain Lion 10.8, NSDeviceRGBColorSpace is treated as sRGB. See WWDC 2012 Session 523: “Best Practices for Color Management”.

I can use a system-wide color meter to see an image file's RGB data.

False. You can use a color meter to approximate the file's original data, but there is no guarantee that one or more lossy color conversions haven't already occured. In order to see the file's original data, you need open the file in an image editor and use its built-in color meter or eyedropper tool. Note that even then, the data may not be accurate, as system image APIs may have performed a color conversion upon opening.

Apple uses sRGB displays — hence, my display's native values are the same as sRGB.

False. While Apple displays in the 2012-2015 timeframe were close to sRGB, minor errors would still occur. In late 2015, Apple introduced iMacs using wider-gamut displays. Trying to use native values from these displays in an sRGB context will result in noticeably incorrect colors.

Due to color conversion, a system-wide color meter is useless.

False. As long as a meter displays values in a standard color space (such as sRGB) and reports potential clipping issues, the meter should be accurate for most development purposes. The development environment must perform proper color management and use the same standard color space, however.

My recommendation is to always keep color meters and development tools in sRGB.

If you are using a near-sRGB display, you can set its profile to be sRGB. This results in a slight loss of color accuracy in exchange for less clipping errors.

If you are on a wide-gamut display, you should instead use the native color profile and live with sRGB→Native rounding errors. If you are a web developer on a wide-gamut display, use Safari for development rather than Chrome (until it treats CSS colors as sRGB).

Article Assumptions

A basic understanding of digital images and color management is assumed:

  • An image comprises pixels arranged in a two dimensional grid. Each pixelcomprises one or many channels.The channels used in most color images are “red”, “green”, and “blue”.
  • Each channel of each pixel has a numeric value. Full intensity is commonly representedas 1.0, 100%, 255, or #ff (hexadecimal). Zero intensity is commonly represented as0.0, 0%, 0, or #00.
  • These intensity values are relative. For example, “100% red” in one imagemay be a different color than “100% red” in another image, which is differentthan “The most saturated red that an average human eye can detect”.
  • A “color profile” contains measurements which can convert relativeintensity values to an absolute, measurable real-life color. If both arecording device (camera, scanner) and a reproduction device (monitor, printer)have accurate color profiles, and color profile information wasn't discarded during editing;the reproduced color should be an accurate representation of the original color.
  • Each image may contain (“embed”) a color profile. If an image lacks a color profile,it will be displayed differently among devices and programs.
  • It is very common for images to not contain color profiles.

If needed, please consult these excellent resources on colormanagement.

macOS Color Management

Each graphics buffer (bytes filled with image data) in macOS has an associatedcolor profile attached to it. If two buffers have different profiles, and the contents of one is drawn into the other;the system performs color conversion.

Consider a simple application which loads an image from disk and draws it into a window. A minimum of three buffers willbe used:

  1. The buffer corresponding to the loaded image file.
  2. The buffer corresponding to the application's window
  3. The buffer assigned to the system's monitor

All system-wide color utilities (including the default Digital Color Meter, my Classic Color Meter, and the system's Color Picker) access the contents of the last buffer (the one associated with a monitor). Any buffer prior to the last is ownedby the window's application and not accessible using macOS's public function calls.

As long as each buffer uses the same color profile, no color conversion occurs. This means that the value seen in a color meterutility is the same as the original value in the image file. However, when different profiles are involved, the value shown bya color meters will not be the same as the original value in the file.

In Snow Leopard 10.6 and prior, it was common for the profiles of all buffers to match,even when using multiple monitors. Thus, color meters commonly reflected the original imagefile's values.

In Lion 10.7, users with multiple monitors noticed that color meters “did notshow the correct value” when sampling off of the secondary display. This was due toa buffer being assigned the main display's color profile, and then being drawn into thesecondary display's buffer (thus resulting in a conversion).

In Mountain Lion 10.8, color management changed again. When an image lacks its own profile,the system now defaults to sRGB rather than themain display's color profile. This results in more frequent color conversions (and thus color metermismatches). Mountain Lion also changed the behavior of many color-related APIs. Calls such as NSColor's +colorWithDeviceRed:green:blue:alpha:were changed to return a color in the sRGB color space rather than the monitor's color space. (Specifically, NSDeviceRGBColorSpace is now treated equal to the sRGB space.)This is covered in WWDC 2012 Session 523: “Best Practices for Color Management”.

The behaviors mentioned above are guidelines — individual applications may use additional buffers and/orexplicitly assign color profiles. A test image is provided at the end of this articlewhich can be loaded in an application and then sampled using a color meter.

Basic Examples

Let's walk through a few basic examples. In all of these, an image without a color profile isdrawn directly to the screen and then sampled with a color meter utility. These examples do notshow the window's buffer, as it will have the same color profile as the display on which it islocated.

Example 1 - Lion 10.7: Image without profile, main display

1A — On Disk
R 255
B 0
Main Display profile
R 255
B 0
Main Display profile
R 255
B 0
“native values”
R 255
B 0

Suppose that we have an image of a yellow box. The raw bytes of the file consist of a repeated pattern of the bytes [255, 255, 0] (pure yellow, or #ffff00). There is no color profile embedded in the image (Figure 1A).

When macOS loads our image into memory, no color space conversion is applied to the repeating pattern of [255, 255, 0]. However, the system needs to assign a color profile at this time. In versions of macOS prior to 10.8, when an image lacks an embedded profile, the main display's profile is assigned. Thus, in memory, our image is still [255, 255, 0], but now is in the main display's color space (Figure 1B).

When the image is drawn, macOS performs a color space conversion if the image's profile doesn't match the destination profile. In this example, we are viewing the image on the main display; thus, no conversion occurs (Figure 1C).

We now sample the color in our meter, with “native values” selected. Since no color space conversion occured, we see the original [255, 255, 0] values of the file (Figure 1D).

Example 2 - Lion 10.7: Image without color profile, second display

no color profile
R 255
B 0
Main Display profile
R 255
B 0
2nd Display profile
R 248
B 45
“native values”
R 252
B 45
“Convert to main display”
R 254
B 1

Let's take our yellow box image and move it to the second display. As in Example 1, the image contains a repeating pattern of [255, 255, 0] and has no embedded color profile (Figure 2A).

Again, when macOS initially loads our image into memory, no color space conversion is applied to the repeating pattern of [255, 255, 0]. However, it still needs to assign a color profile at this time. The operating system isn't psychic (yet), so it doesn't know that it will be rendering the image on the second display. Hence, the main display's profile is once again assigned (Figure 2B).

Now, when the image is drawn, a color space conversion to the second display's profile occurs. Due to the conversion, the RGB values no longer match the file (Figure 2C). When viewed in our color meter with “native values” selected, these screen values are used (Figure 2D).

By selecting “Convert to main display” in our color meter, we can apply another color space conversion back to the main display. Due to conversion errors, this value isn't the exact same as the original, but it's close.

Example 3 - Modern macOS: Image without profile

no color profile
R 255
B 0
sRGB profile
R 255
B 0
Main Display profile
R 254
B 56
“native values”
R 254
B 56
“Display in sRGB”
R 255
B -2

Let's take our yellow box image and load it onto a modern (10.8+) version of macOS . As in the first two examples,the image on disk is a repeating pattern of [255, 255, 0]; and has no embedded color profile (Figure 3A).

In Mountain Lion, when an image lacks an embedded profile, the sRGB color space is assigned. Thus, in memory, our image is still [255, 255, 0], but now is in sRGB. (Figure 3B).

When the image is drawn to either display, macOS will perform a color space conversion (Figure 3C). These converted values will also appear in our meter (Figure 3D).

By selecting “Display in sRGB” in our meter, we can convert back to the original values in the file. Again, due to the conversion errors, it's not the same as the original, but close (Figure 3E).

Conversion Errors

Unfortuately, when colors are stored as bytes ranging from 0-255, each color conversion can lose information. This results in two types of errors: rounding and clipping.

Example 4 - Rounding Errors

R 255
B 0
(raw)
R 248.49
B 44.55
(rounded)
R 248
B 45
(raw)
R 254.49
B 0.53
(rounded)
R 254
B 1

Rounding errors occur due to the color conversion rounding a raw floating-point value back into a 0-255 integer value.

Download

Let's take a closer look at the color conversion from Example 2. When we applied the Main Display → 2nd Display color conversion, [255, 255, 0] seemingly transformed into [248, 255, 45]. However, behind the scenes, it actually transformed into [248.49, 255.06, 44.55], which was then rounded.

This is fine, as [248, 255, 45] is the closest color on the 2nd Display. However, our reverse 2nd Display → Main Display conversion has no way of using the non-rounded values. The final result is close to the original value, but not exact.

Example 5 - Clipping Errors

Clipping errors can be more severe. They occur when a color conversion takes a value above 255 or below 0. To demonstrate an extreme case, we will use the following color profiles, which use noticeably different positions for the green point.

Let's convert [0, 255, 0] (pure green, or #00ff00) in sRGB to the Main Display's profile.

R 0
B 0
(raw)
R -90.09
B 83.41
(rounded & clipped)
R 0
B 83
(raw)
R 86.37
B -4.90
(rounded & clipped)
R 86
B 0

Due to the different green points, each conversion will alter the red and blue values significantly. In Figure 5B, red is taken to -90.09. Since we are storing these values in bytes ranging from 0-255, red is cropped to 0 (Figure 5C).

While this is the closet color representation on the Main Display, the dramatic information loss causes issues if we want to convert back to sRGB. In Figure 4D, the reverse conversion bumps red to 86.37 and drops blue to -4.90. Once clipped, this results in a more yellowish-green color than we originally had.

Color Faker (Do Not Use)

Srgb color profile download

When Mountain Lion 10.8 introduced the new assume-no-profile-is-sRGB behavior, I wrote a utilitycalled ColorFaker which attempted to restore theLion 10.7 behavior. It was a hack, but worked as a stopgap during 10.8 and 10.9.

In Yosemite 10.10, ColorFaker causes crashes. In El Capitan 10.11, System Integrity Protection renders it completely useless.

I have since discontinued development and strongly recommend against using ColorFaker.

Test Image & HTML Table

Download Srgb Color Profile Mac Os

When in doubt, sample the color management behavior of an application yourself. Drag the following test image to your desktop,then open it in a target application. Set your color meter to “Use native values” and move the mouse cursorover each color swatch. If the values reported by the meter align with the text printed in the file, no color conversion isbeing applied.

Also provided is an HTML table stylized with CSS background colors. This can be used in combination with a color meter to determine how browsers handle CSS colors:
FF,00,0000,FF,0000,00,FFFF,FF,FF
AA,00,0000,AA,0000,00,AAAA,AA,AA
FF,00,FFFF,FF,0000,FF,FF00,00,00
55,00,5555,55,0000,55,5555,55,55

Frequently Asked Questions

Why is Apple doing this?

I have no knowledge of Apple's goals, but I suspect they desire to offer wider-gamut displays to consumers (with the late 2015 Retina iMac as the first example). If you could install Snow Leopard 10.6 on one of these machines, the old “use the display profile for untagged colors” behavior would result in oversaturation due to the wider DCI-P3 color space.

In addition, these changes align macOS with other operating systems and web standards. For example, the CSS Color Module specification has always stated that colors are in sRGB.

What could Apple do better?

There are different approaches that Apple could take, but they all involve trade-offs.

At the time of this writing (10.11), most buffers use a bit depth of 8 bits per channel, with a value range of 0 for pure black to 255 for pure white. If the bit depth were increased to 10 or 12 bits per channel, rounding errors could be less severe. If the value range were altered to allow sub-black and super-white values, clipping errors would be reduced (although there should be no clipping when going from sRGB to DCI-P3). However, these changes would also increase memory footprint and decrease graphics performance.

Alternatively, the system could use sRGB for all buffers. This would eliminate many conversion errors, but would prevent deep-color images from displaying as-intended on wider-gamut devices. There could also be double conversions (once to sRGB, once to the display's space), which would decrease performance. This isn't a good solution for consumers, as it effectively turns the DCI-P3 display into an sRGB one; however, it would be great for developers/designers that need to work in sRGB.

Can I select sRGB as my monitor's profile to prevent conversions?

Download Srgb Profile

Yes, if you specify sRGB as your monitors display profile, several color conversions will be eliminated. However, the actual color accuracy of your display will be compromised.

If you are on a near-sRGB display, such as the Late 2014 Retina iMac or Late 2013 Retina MacBook Pro, the accuracy loss is small and likely acceptable. If you are on a wide-gamut display, such as the P3 display in the Late 2015 Retina iMac, this technique will result in oversaturated colors.

Additional Reading

  • Cambridge in Colour articles
  • Wikipedia Articles
  • Other Links

sRGB Appearance profile

Download Srgb Color Profile Mac Os

An sRGB Appearance profile has been developed, and has been tested internally and externally.

This profile is a v4 replacement for commonly used sRGB v2 profiles. It gives better results in workflows that implement the ICC v4 specification, and is intended to be used in combination with other ICC v4 profiles.

The ICC specification allows there to be more than one Perceptual Rendering from a given source colour space. For sRGB, ICC provides the Preference and Appearance profiles, both of which provide standard color transforms from sRGB to the perceptual reference medium gamut (PRMG). These two color profiles can be thought of as re-targeting and re-purposing as described in ICC White Paper 02. The difference between these two profiles is in the Perceptual Rendering; other Rendering Intents are the same. A full description and intended use for the sRGB v4 ICC preference profile is described in ICC White Paper 26.

The features of the Appearance Profile are that it:

  • May be used as re-targeting in perceptual rendering intent.
  • Produces more color-consistent results in color reproduction on display.
  • Produces more pleasing results in appearance and tone scaling for most images than Colorimetric Rendering.
The Appearance profile is particularly recommended when the difference between source gamut and destination gamut is large and it is desired to 're-purpose' the image (i.e. make it optimal for the reproduction medium - see ICC White Papers 1 and 2 for more on re-purposing and re-targeting of color).

For more information on the ICC sRGB Appearance Profile, please see ICC White Paper 42.

Terms of use

To anyone who acknowledges that the file 'sRGB_ICC_v4_Appearance.icc' is provided 'AS IS' WITH NO EXPRESS OR IMPLIED WARRANTY, permission to use, copy and distribute these file for any purpose is hereby granted without fee, provided that the files are not changed including the ICC copyright notice tag, and that the name of ICC shall not be used in advertising or publicity pertaining to distribution of the software without specific, written prior permission. ICC makes no representations about the suitability of this software for any purpose.

[Updated 7 June 2016. B2A0 table updated for better handle colours outside of PRM Gamut; A2B1 and B2A1 tables updated to conform to IEC 61966-1 (sRGB) 2014 corrigendum.]