blob: 4a71bc8c41caf794888263064baf71f6ece6d6e8 [file] [log] [blame]
Jason Sams01e9f902013-06-18 11:53:03 -07001/*
2 * Copyright (C) 2013 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package android.renderscript;
18
Jason Sams01e9f902013-06-18 11:53:03 -070019/**
20 * Intrinsic Histogram filter.
21 *
Xusong Wang8b4548c2021-01-05 10:09:52 -080022 * @deprecated Renderscript has been deprecated in API level 31. Please refer to the <a
23 * href="https://developer.android.com/guide/topics/renderscript/migration-guide">migration
24 * guide</a> for the proposed alternatives.
Jason Sams01e9f902013-06-18 11:53:03 -070025 **/
Xusong Wang8b4548c2021-01-05 10:09:52 -080026@Deprecated
Jason Sams01e9f902013-06-18 11:53:03 -070027public final class ScriptIntrinsicHistogram extends ScriptIntrinsic {
28 private Allocation mOut;
29
Tim Murray460a0492013-11-19 12:45:54 -080030 private ScriptIntrinsicHistogram(long id, RenderScript rs) {
Jason Sams01e9f902013-06-18 11:53:03 -070031 super(id, rs);
32 }
33
34 /**
35 * Create an intrinsic for calculating the histogram of an uchar
36 * or uchar4 image.
37 *
Jason Sams92743842013-06-18 18:52:42 -070038 * Supported elements types are
39 * {@link Element#U8_4}, {@link Element#U8_3},
40 * {@link Element#U8_2}, {@link Element#U8}
Jason Sams01e9f902013-06-18 11:53:03 -070041 *
42 * @param rs The RenderScript context
Jason Sams1a3edb02013-06-18 18:23:37 -070043 * @param e Element type for inputs
Jason Sams01e9f902013-06-18 11:53:03 -070044 *
45 * @return ScriptIntrinsicHistogram
46 */
47 public static ScriptIntrinsicHistogram create(RenderScript rs, Element e) {
Jason Sams1a3edb02013-06-18 18:23:37 -070048 if ((!e.isCompatible(Element.U8_4(rs))) &&
49 (!e.isCompatible(Element.U8_3(rs))) &&
50 (!e.isCompatible(Element.U8_2(rs))) &&
51 (!e.isCompatible(Element.U8(rs)))) {
Stephen Hinesad57e332016-04-11 13:05:55 -070052 throw new RSIllegalArgumentException("Unsupported element type.");
Jason Sams01e9f902013-06-18 11:53:03 -070053 }
Tim Murray460a0492013-11-19 12:45:54 -080054 long id = rs.nScriptIntrinsicCreate(9, e.getID(rs));
Jason Sams01e9f902013-06-18 11:53:03 -070055 ScriptIntrinsicHistogram sib = new ScriptIntrinsicHistogram(id, rs);
56 return sib;
57 }
58
Jason Sams1a3edb02013-06-18 18:23:37 -070059 /**
60 * Process an input buffer and place the histogram into the
61 * output allocation. The output allocation may be a narrower
62 * vector size than the input. In this case the vector size of
63 * the output is used to determine how many of the input
64 * channels are used in the computation. This is useful if you
65 * have an RGBA input buffer but only want the histogram for
66 * RGB.
67 *
68 * 1D and 2D input allocations are supported.
69 *
70 * @param ain The input image
71 */
Jason Sams01e9f902013-06-18 11:53:03 -070072 public void forEach(Allocation ain) {
Tim Murray6f842ac2014-01-13 11:47:53 -080073 forEach(ain, null);
74 }
75
76 /**
77 * Process an input buffer and place the histogram into the
78 * output allocation. The output allocation may be a narrower
79 * vector size than the input. In this case the vector size of
80 * the output is used to determine how many of the input
81 * channels are used in the computation. This is useful if you
82 * have an RGBA input buffer but only want the histogram for
83 * RGB.
84 *
85 * 1D and 2D input allocations are supported.
86 *
87 * @param ain The input image
88 * @param opt LaunchOptions for clipping
89 */
90 public void forEach(Allocation ain, Script.LaunchOptions opt) {
Jason Sams8ace2ac2013-06-18 17:34:34 -070091 if (ain.getType().getElement().getVectorSize() <
92 mOut.getType().getElement().getVectorSize()) {
93
94 throw new RSIllegalArgumentException(
Jason Sams1a3edb02013-06-18 18:23:37 -070095 "Input vector size must be >= output vector size.");
Jason Sams01e9f902013-06-18 11:53:03 -070096 }
Miao Wangb590b352015-01-15 11:09:23 -080097 if (!ain.getType().getElement().isCompatible(Element.U8(mRS)) &&
Miao Wang8a126532015-01-23 09:41:04 -080098 !ain.getType().getElement().isCompatible(Element.U8_2(mRS)) &&
99 !ain.getType().getElement().isCompatible(Element.U8_3(mRS)) &&
Miao Wangb590b352015-01-15 11:09:23 -0800100 !ain.getType().getElement().isCompatible(Element.U8_4(mRS))) {
Miao Wang8a126532015-01-23 09:41:04 -0800101 throw new RSIllegalArgumentException("Input type must be U8, U8_1, U8_2 or U8_4.");
Jason Sams01e9f902013-06-18 11:53:03 -0700102 }
103
Tim Murray6f842ac2014-01-13 11:47:53 -0800104 forEach(0, ain, null, null, opt);
Jason Sams01e9f902013-06-18 11:53:03 -0700105 }
106
Tim Murray6f842ac2014-01-13 11:47:53 -0800107
108
Jason Sams1a3edb02013-06-18 18:23:37 -0700109 /**
110 * Set the coefficients used for the RGBA to Luminocity
111 * calculation. The default is {0.299f, 0.587f, 0.114f, 0.f}.
112 *
113 * Coefficients must be >= 0 and sum to 1.0 or less.
114 *
115 * @param r Red coefficient
116 * @param g Green coefficient
117 * @param b Blue coefficient
118 * @param a Alpha coefficient
119 */
Jason Sams01e9f902013-06-18 11:53:03 -0700120 public void setDotCoefficients(float r, float g, float b, float a) {
121 if ((r < 0.f) || (g < 0.f) || (b < 0.f) || (a < 0.f)) {
122 throw new RSIllegalArgumentException("Coefficient may not be negative.");
123 }
124 if ((r + g + b + a) > 1.f) {
125 throw new RSIllegalArgumentException("Sum of coefficients must be 1.0 or less.");
126 }
127
128 FieldPacker fp = new FieldPacker(16);
129 fp.addF32(r);
130 fp.addF32(g);
131 fp.addF32(b);
132 fp.addF32(a);
133 setVar(0, fp);
134 }
135
136 /**
Jason Sams1a3edb02013-06-18 18:23:37 -0700137 * Set the output of the histogram. 32 bit integer types are
138 * supported.
Jason Sams01e9f902013-06-18 11:53:03 -0700139 *
Jason Sams1a3edb02013-06-18 18:23:37 -0700140 * @param aout The output allocation
Jason Sams01e9f902013-06-18 11:53:03 -0700141 */
142 public void setOutput(Allocation aout) {
143 mOut = aout;
144 if (mOut.getType().getElement() != Element.U32(mRS) &&
Jason Sams8ace2ac2013-06-18 17:34:34 -0700145 mOut.getType().getElement() != Element.U32_2(mRS) &&
Jason Sams01e9f902013-06-18 11:53:03 -0700146 mOut.getType().getElement() != Element.U32_3(mRS) &&
147 mOut.getType().getElement() != Element.U32_4(mRS) &&
148 mOut.getType().getElement() != Element.I32(mRS) &&
Jason Sams8ace2ac2013-06-18 17:34:34 -0700149 mOut.getType().getElement() != Element.I32_2(mRS) &&
Jason Sams01e9f902013-06-18 11:53:03 -0700150 mOut.getType().getElement() != Element.I32_3(mRS) &&
151 mOut.getType().getElement() != Element.I32_4(mRS)) {
152
153 throw new RSIllegalArgumentException("Output type must be U32 or I32.");
154 }
155 if ((mOut.getType().getX() != 256) ||
156 (mOut.getType().getY() != 0) ||
157 mOut.getType().hasMipmaps() ||
158 (mOut.getType().getYuv() != 0)) {
159
160 throw new RSIllegalArgumentException("Output must be 1D, 256 elements.");
161 }
162 setVar(1, aout);
163 }
164
Tim Murray6f842ac2014-01-13 11:47:53 -0800165
Jason Sams1a3edb02013-06-18 18:23:37 -0700166 /**
167 * Process an input buffer and place the histogram into the
168 * output allocation. The dot product of the input channel and
169 * the coefficients from 'setDotCoefficients' are used to
170 * calculate the output values.
171 *
172 * 1D and 2D input allocations are supported.
173 *
174 * @param ain The input image
175 */
Jason Samsa49e89d2013-08-29 17:00:37 -0700176 public void forEach_Dot(Allocation ain) {
Tim Murray6f842ac2014-01-13 11:47:53 -0800177 forEach_Dot(ain, null);
178 }
179
180 /**
181 * Process an input buffer and place the histogram into the
182 * output allocation. The dot product of the input channel and
183 * the coefficients from 'setDotCoefficients' are used to
184 * calculate the output values.
185 *
186 * 1D and 2D input allocations are supported.
187 *
188 * @param ain The input image
189 * @param opt LaunchOptions for clipping
190 */
191 public void forEach_Dot(Allocation ain, Script.LaunchOptions opt) {
Jason Sams01e9f902013-06-18 11:53:03 -0700192 if (mOut.getType().getElement().getVectorSize() != 1) {
193 throw new RSIllegalArgumentException("Output vector size must be one.");
194 }
Miao Wangb590b352015-01-15 11:09:23 -0800195 if (!ain.getType().getElement().isCompatible(Element.U8(mRS)) &&
Miao Wang8a126532015-01-23 09:41:04 -0800196 !ain.getType().getElement().isCompatible(Element.U8_2(mRS)) &&
197 !ain.getType().getElement().isCompatible(Element.U8_3(mRS)) &&
Miao Wangb590b352015-01-15 11:09:23 -0800198 !ain.getType().getElement().isCompatible(Element.U8_4(mRS))) {
Miao Wang8a126532015-01-23 09:41:04 -0800199 throw new RSIllegalArgumentException("Input type must be U8, U8_1, U8_2 or U8_4.");
Jason Sams01e9f902013-06-18 11:53:03 -0700200 }
201
Tim Murray6f842ac2014-01-13 11:47:53 -0800202 forEach(1, ain, null, null, opt);
Jason Sams01e9f902013-06-18 11:53:03 -0700203 }
204
205
206
207 /**
208 * Get a KernelID for this intrinsic kernel.
209 *
210 * @return Script.KernelID The KernelID object.
211 */
Jason Samsa49e89d2013-08-29 17:00:37 -0700212 public Script.KernelID getKernelID_Separate() {
Jason Sams01e9f902013-06-18 11:53:03 -0700213 return createKernelID(0, 3, null, null);
214 }
215
216 /**
217 * Get a FieldID for the input field of this intrinsic.
218 *
219 * @return Script.FieldID The FieldID object.
220 */
221 public Script.FieldID getFieldID_Input() {
222 return createFieldID(1, null);
223 }
224}
225