1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155
|
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<!-- Created by GNU Texinfo 6.1, http://www.gnu.org/software/texinfo/ -->
<head>
<title>GNU Octave: Color Conversion</title>
<meta name="description" content="GNU Octave: Color Conversion">
<meta name="keywords" content="GNU Octave: Color Conversion">
<meta name="resource-type" content="document">
<meta name="distribution" content="global">
<meta name="Generator" content="makeinfo">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<link href="index.html#Top" rel="start" title="Top">
<link href="Concept-Index.html#Concept-Index" rel="index" title="Concept Index">
<link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
<link href="Image-Processing.html#Image-Processing" rel="up" title="Image Processing">
<link href="Audio-Processing.html#Audio-Processing" rel="next" title="Audio Processing">
<link href="Plotting-on-top-of-Images.html#Plotting-on-top-of-Images" rel="prev" title="Plotting on top of Images">
<style type="text/css">
<!--
a.summary-letter {text-decoration: none}
blockquote.indentedblock {margin-right: 0em}
blockquote.smallindentedblock {margin-right: 0em; font-size: smaller}
blockquote.smallquotation {font-size: smaller}
div.display {margin-left: 3.2em}
div.example {margin-left: 3.2em}
div.lisp {margin-left: 3.2em}
div.smalldisplay {margin-left: 3.2em}
div.smallexample {margin-left: 3.2em}
div.smalllisp {margin-left: 3.2em}
kbd {font-style: oblique}
pre.display {font-family: inherit}
pre.format {font-family: inherit}
pre.menu-comment {font-family: serif}
pre.menu-preformatted {font-family: serif}
pre.smalldisplay {font-family: inherit; font-size: smaller}
pre.smallexample {font-size: smaller}
pre.smallformat {font-family: inherit; font-size: smaller}
pre.smalllisp {font-size: smaller}
span.nolinebreak {white-space: nowrap}
span.roman {font-family: initial; font-weight: normal}
span.sansserif {font-family: sans-serif; font-weight: normal}
ul.no-bullet {list-style: none}
-->
</style>
</head>
<body lang="en">
<a name="Color-Conversion"></a>
<div class="header">
<p>
Previous: <a href="Plotting-on-top-of-Images.html#Plotting-on-top-of-Images" accesskey="p" rel="prev">Plotting on top of Images</a>, Up: <a href="Image-Processing.html#Image-Processing" accesskey="u" rel="up">Image Processing</a> [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html#Concept-Index" title="Index" rel="index">Index</a>]</p>
</div>
<hr>
<a name="Color-Conversion-1"></a>
<h3 class="section">32.5 Color Conversion</h3>
<p>Octave supports conversion from the RGB color system to NTSC and HSV
and vice versa.
</p>
<a name="XREFrgb2hsv"></a><dl>
<dt><a name="index-rgb2hsv"></a>Function File: <em><var>hsv_map</var> =</em> <strong>rgb2hsv</strong> <em>(<var>rgb</var>)</em></dt>
<dt><a name="index-rgb2hsv-1"></a>Function File: <em><var>hsv_map</var> =</em> <strong>rgb2hsv</strong> <em>(<var>rgb</var>)</em></dt>
<dd><p>Transform a colormap or image from red-green-blue (RGB) space to
hue-saturation-value (HSV) space.
</p>
<p>A color in the RGB space consists of red, green, and blue intensities.
</p>
<p>A color in HSV space is represented by hue, saturation, and value
(brightness) levels. Value gives the amount of light in the color. Hue
describes the dominant wavelength. Saturation is the amount of hue mixed
into the color.
</p>
<p><strong>See also:</strong> <a href="#XREFhsv2rgb">hsv2rgb</a>, <a href="Representing-Images.html#XREFrgb2ind">rgb2ind</a>, <a href="#XREFrgb2ntsc">rgb2ntsc</a>.
</p></dd></dl>
<a name="XREFhsv2rgb"></a><dl>
<dt><a name="index-hsv2rgb"></a>Function File: <em><var>rgb_map</var> =</em> <strong>hsv2rgb</strong> <em>(<var>hsv_map</var>)</em></dt>
<dt><a name="index-hsv2rgb-1"></a>Function File: <em><var>rgb_img</var> =</em> <strong>hsv2rgb</strong> <em>(<var>hsv_img</var>)</em></dt>
<dd><p>Transform a colormap or image from hue-saturation-value (HSV) space to
red-green-blue (RGB) space.
</p>
<p>A color in HSV space is represented by hue, saturation and value
(brightness) levels. Value gives the amount of light in the color. Hue
describes the dominant wavelength. Saturation is the amount of hue mixed
into the color.
</p>
<p>A color in the RGB space consists of red, green, and blue intensities.
</p>
<p><strong>See also:</strong> <a href="#XREFrgb2hsv">rgb2hsv</a>, <a href="Representing-Images.html#XREFind2rgb">ind2rgb</a>, <a href="#XREFntsc2rgb">ntsc2rgb</a>.
</p></dd></dl>
<a name="XREFrgb2ntsc"></a><dl>
<dt><a name="index-rgb2ntsc"></a>Function File: <em><var>yiq_map</var> =</em> <strong>rgb2ntsc</strong> <em>(<var>rgb_map</var>)</em></dt>
<dt><a name="index-rgb2ntsc-1"></a>Function File: <em><var>yiq_img</var> =</em> <strong>rgb2ntsc</strong> <em>(<var>rgb_img</var>)</em></dt>
<dd><p>Transform a colormap or image from red-green-blue (RGB) color space to
luminance-chrominance (NTSC) space. The input may be of class uint8,
uint16, single, or double. The output is of class double.
</p>
<p>Implementation Note:
The reference matrix for the transformation is
</p>
<div class="example">
<pre class="example">/Y\ 0.299 0.587 0.114 /R\
|I| = 0.596 -0.274 -0.322 |G|
\Q/ 0.211 -0.523 0.312 \B/
</pre></div>
<p>as documented in <a href="http://en.wikipedia.org/wiki/YIQ">http://en.wikipedia.org/wiki/YIQ</a> and truncated to 3
significant figures. Note: The FCC version of NTSC uses only 2 significant
digits and is slightly different.
</p>
<p><strong>See also:</strong> <a href="#XREFntsc2rgb">ntsc2rgb</a>, <a href="#XREFrgb2hsv">rgb2hsv</a>, <a href="Representing-Images.html#XREFrgb2ind">rgb2ind</a>.
</p></dd></dl>
<a name="XREFntsc2rgb"></a><dl>
<dt><a name="index-ntsc2rgb"></a>Function File: <em><var>rgb_map</var> =</em> <strong>ntsc2rgb</strong> <em>(<var>yiq_map</var>)</em></dt>
<dt><a name="index-ntsc2rgb-1"></a>Function File: <em><var>rgb_img</var> =</em> <strong>ntsc2rgb</strong> <em>(<var>yiq_img</var>)</em></dt>
<dd><p>Transform a colormap or image from luminance-chrominance (NTSC) space to
red-green-blue (RGB) color space.
</p>
<p>Implementation Note:
The conversion matrix is chosen to be the inverse of the matrix used for
rgb2ntsc such that
</p>
<div class="example">
<pre class="example">x == ntsc2rgb (rgb2ntsc (x))
</pre></div>
<p><small>MATLAB</small> uses a slightly different matrix where rounding means the
equality above does not hold.
</p>
<p><strong>See also:</strong> <a href="#XREFrgb2ntsc">rgb2ntsc</a>, <a href="#XREFhsv2rgb">hsv2rgb</a>, <a href="Representing-Images.html#XREFind2rgb">ind2rgb</a>.
</p></dd></dl>
<hr>
<div class="header">
<p>
Previous: <a href="Plotting-on-top-of-Images.html#Plotting-on-top-of-Images" accesskey="p" rel="prev">Plotting on top of Images</a>, Up: <a href="Image-Processing.html#Image-Processing" accesskey="u" rel="up">Image Processing</a> [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html#Concept-Index" title="Index" rel="index">Index</a>]</p>
</div>
</body>
</html>
|