blob: 661db0a89f3d8361d3e2d411c8e2bd10505c9dc5 [file] [log] [blame]
/*
* Copyright (C) 2013 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package android.renderscript;
/**
* Vector version of the basic short type.
* Provides three short fields packed.
*/
public class Short3 {
public short x;
public short y;
public short z;
public Short3() {
}
/** @hide */
public Short3(short i) {
this.x = this.y = this.z = i;
}
public Short3(short x, short y, short z) {
this.x = x;
this.y = y;
this.z = z;
}
/** @hide */
public Short3(Short3 source) {
this.x = source.x;
this.y = source.y;
this.z = source.z;
}
/** @hide
* Vector add
*
* @param a
*/
public void add(Short3 a) {
this.x += a.x;
this.y += a.y;
this.z += a.z;
}
/** @hide
* Vector add
*
* @param a
* @param b
* @return
*/
public static Short3 add(Short3 a, Short3 b) {
Short3 result = new Short3();
result.x = (short)(a.x + b.x);
result.y = (short)(a.y + b.y);
result.z = (short)(a.z + b.z);
return result;
}
/** @hide
* Vector add
*
* @param value
*/
public void add(short value) {
x += value;
y += value;
z += value;
}
/** @hide
* Vector add
*
* @param a
* @param b
* @return
*/
public static Short3 add(Short3 a, short b) {
Short3 result = new Short3();
result.x = (short)(a.x + b);
result.y = (short)(a.y + b);
result.z = (short)(a.z + b);
return result;
}
/** @hide
* Vector subtraction
*
* @param a
*/
public void sub(Short3 a) {
this.x -= a.x;
this.y -= a.y;
this.z -= a.z;
}
/** @hide
* Vector subtraction
*
* @param a
* @param b
* @return
*/
public static Short3 sub(Short3 a, Short3 b) {
Short3 result = new Short3();
result.x = (short)(a.x - b.x);
result.y = (short)(a.y - b.y);
result.z = (short)(a.z - b.z);
return result;
}
/** @hide
* Vector subtraction
*
* @param value
*/
public void sub(short value) {
x -= value;
y -= value;
z -= value;
}
/** @hide
* Vector subtraction
*
* @param a
* @param b
* @return
*/
public static Short3 sub(Short3 a, short b) {
Short3 result = new Short3();
result.x = (short)(a.x - b);
result.y = (short)(a.y - b);
result.z = (short)(a.z - b);
return result;
}
/** @hide
* Vector multiplication
*
* @param a
*/
public void mul(Short3 a) {
this.x *= a.x;
this.y *= a.y;
this.z *= a.z;
}
/** @hide
* Vector multiplication
*
* @param a
* @param b
* @return
*/
public static Short3 mul(Short3 a, Short3 b) {
Short3 result = new Short3();
result.x = (short)(a.x * b.x);
result.y = (short)(a.y * b.y);
result.z = (short)(a.z * b.z);
return result;
}
/** @hide
* Vector multiplication
*
* @param value
*/
public void mul(short value) {
x *= value;
y *= value;
z *= value;
}
/** @hide
* Vector multiplication
*
* @param a
* @param b
* @return
*/
public static Short3 mul(Short3 a, short b) {
Short3 result = new Short3();
result.x = (short)(a.x * b);
result.y = (short)(a.y * b);
result.z = (short)(a.z * b);
return result;
}
/** @hide
* Vector division
*
* @param a
*/
public void div(Short3 a) {
this.x /= a.x;
this.y /= a.y;
this.z /= a.z;
}
/** @hide
* Vector division
*
* @param a
* @param b
* @return
*/
public static Short3 div(Short3 a, Short3 b) {
Short3 result = new Short3();
result.x = (short)(a.x / b.x);
result.y = (short)(a.y / b.y);
result.z = (short)(a.z / b.z);
return result;
}
/** @hide
* Vector division
*
* @param value
*/
public void div(short value) {
x /= value;
y /= value;
z /= value;
}
/** @hide
* Vector division
*
* @param a
* @param b
* @return
*/
public static Short3 div(Short3 a, short b) {
Short3 result = new Short3();
result.x = (short)(a.x / b);
result.y = (short)(a.y / b);
result.z = (short)(a.z / b);
return result;
}
/** @hide
* Vector Modulo
*
* @param a
*/
public void mod(Short3 a) {
this.x %= a.x;
this.y %= a.y;
this.z %= a.z;
}
/** @hide
* Vector Modulo
*
* @param a
* @param b
* @return
*/
public static Short3 mod(Short3 a, Short3 b) {
Short3 result = new Short3();
result.x = (short)(a.x % b.x);
result.y = (short)(a.y % b.y);
result.z = (short)(a.z % b.z);
return result;
}
/** @hide
* Vector Modulo
*
* @param value
*/
public void mod(short value) {
x %= value;
y %= value;
z %= value;
}
/** @hide
* Vector Modulo
*
* @param a
* @param b
* @return
*/
public static Short3 mod(Short3 a, short b) {
Short3 result = new Short3();
result.x = (short)(a.x % b);
result.y = (short)(a.y % b);
result.z = (short)(a.z % b);
return result;
}
/** @hide
* get vector length
*
* @return
*/
public short length() {
return 3;
}
/** @hide
* set vector negate
*/
public void negate() {
this.x = (short)(-x);
this.y = (short)(-y);
this.z = (short)(-z);
}
/** @hide
* Vector dot Product
*
* @param a
* @return
*/
public short dotProduct(Short3 a) {
return (short)((x * a.x) + (y * a.y) + (z * a.z));
}
/** @hide
* Vector dot Product
*
* @param a
* @param b
* @return
*/
public static short dotProduct(Short3 a, Short3 b) {
return (short)((b.x * a.x) + (b.y * a.y) + (b.z * a.z));
}
/** @hide
* Vector add Multiple
*
* @param a
* @param factor
*/
public void addMultiple(Short3 a, short factor) {
x += a.x * factor;
y += a.y * factor;
z += a.z * factor;
}
/** @hide
* set vector value by Short3
*
* @param a
*/
public void set(Short3 a) {
this.x = a.x;
this.y = a.y;
this.z = a.z;
}
/** @hide
* set the vector field value by Short
*
* @param a
* @param b
* @param c
*/
public void setValues(short a, short b, short c) {
this.x = a;
this.y = b;
this.z = c;
}
/** @hide
* return the element sum of vector
*
* @return
*/
public short elementSum() {
return (short)(x + y + z);
}
/** @hide
* get the vector field value by index
*
* @param i
* @return
*/
public short get(int i) {
switch (i) {
case 0:
return (short)(x);
case 1:
return (short)(y);
case 2:
return (short)(z);
default:
throw new IndexOutOfBoundsException("Index: i");
}
}
/** @hide
* set the vector field value by index
*
* @param i
* @param value
*/
public void setAt(int i, short value) {
switch (i) {
case 0:
x = value;
return;
case 1:
y = value;
return;
case 2:
z = value;
return;
default:
throw new IndexOutOfBoundsException("Index: i");
}
}
/** @hide
* add the vector field value by index
*
* @param i
* @param value
*/
public void addAt(int i, short value) {
switch (i) {
case 0:
x += value;
return;
case 1:
y += value;
return;
case 2:
z += value;
return;
default:
throw new IndexOutOfBoundsException("Index: i");
}
}
/** @hide
* copy the vector to short array
*
* @param data
* @param offset
*/
public void copyTo(short[] data, int offset) {
data[offset] = (short)(x);
data[offset + 1] = (short)(y);
data[offset + 2] = (short)(z);
}
}