com.xxdb.data.BasicShortVector Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dolphindb-javaapi Show documentation
Show all versions of dolphindb-javaapi Show documentation
The messaging and data conversion protocol between Java and DolphinDB server
package com.xxdb.data;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.util.Arrays;
import java.util.List;
import com.xxdb.io.ExtendedDataInput;
import com.xxdb.io.ExtendedDataOutput;
/**
*
* Corresponds to DolphinDB short vector
*
*/
public class BasicShortVector extends AbstractVector{
private short[] values;
private int size;
private int capaticy;
public BasicShortVector(int size){
this(DATA_FORM.DF_VECTOR, size);
}
public BasicShortVector(List list){
super(DATA_FORM.DF_VECTOR);
if (list != null) {
values = new short[list.size()];
for (int i=0; i= 0)
return value % buckets;
else if(value == Short.MIN_VALUE)
return -1;
else{
return (int)((4294967296l + value) % buckets);
}
}
@Override
public int getUnitLength() {
return 2;
}
public void add(short value) {
if (size + 1 > capaticy && values.length > 0){
values = Arrays.copyOf(values, values.length * 2);
}else if (values.length <= 0){
values = Arrays.copyOf(values, values.length + 1);
}
capaticy = values.length;
values[size] = value;
size++;
}
public void addRange(short[] valueList) {
values = Arrays.copyOf(values, valueList.length + values.length);
System.arraycopy(valueList, 0, values, size, valueList.length);
size += valueList.length;
capaticy = values.length;
}
@Override
public void Append(Scalar value) throws Exception{
add(value.getNumber().shortValue());
}
@Override
public void Append(Vector value) throws Exception{
addRange(((BasicShortVector)value).getdataArray());
}
public short[] getdataArray(){
short[] data = new short[size];
System.arraycopy(values, 0, data, 0, size);
return data;
}
@Override
public Vector combine(Vector vector) {
BasicShortVector v = (BasicShortVector)vector;
int newSize = this.rows() + v.rows();
short[] newValue = new short[newSize];
System.arraycopy(this.values,0, newValue,0,this.rows());
System.arraycopy(v.values,0, newValue,this.rows(),v.rows());
return new BasicShortVector(newValue);
}
@Override
public boolean isNull(int index) {
return values[index] == Short.MIN_VALUE;
}
@Override
public void setNull(int index) {
values[index] = Short.MIN_VALUE;
}
@Override
public DATA_CATEGORY getDataCategory() {
return Entity.DATA_CATEGORY.INTEGRAL;
}
@Override
public DATA_TYPE getDataType() {
return Entity.DATA_TYPE.DT_SHORT;
}
@Override
public int rows() {
return size;
}
@Override
public Class> getElementClass(){
return BasicShort.class;
}
@Override
protected void writeVectorToOutputStream(ExtendedDataOutput out) throws IOException {
short[] data = new short[size];
System.arraycopy(values, 0, data, 0, size);
out.writeShortArray(data);
}
@Override
public ByteBuffer writeVectorToBuffer(ByteBuffer buffer) throws IOException {
short[] data = new short[size];
System.arraycopy(values, 0, data, 0, size);
for (short val: data) {
buffer.putShort(val);
}
return buffer;
}
@Override
public int asof(Scalar value) {
short target;
try{
target = value.getNumber().shortValue();
}
catch(Exception ex){
throw new RuntimeException(ex);
}
int start = 0;
int end = size - 1;
int mid;
while(start <= end){
mid = (start + end)/2;
if(values[mid] <= target)
start = mid + 1;
else
end = mid - 1;
}
return end;
}
@Override
public int serialize(int indexStart, int offect, int targetNumElement, NumElementAndPartial numElementAndPartial, ByteBuffer out) throws IOException{
targetNumElement = Math.min((out.remaining() / getUnitLength()), targetNumElement);
for (int i = 0; i < targetNumElement; ++i)
{
out.putShort(values[indexStart + i]);
}
numElementAndPartial.numElement = targetNumElement;
numElementAndPartial.partial = 0;
return targetNumElement * 2;
}
public short[] getValues() {
return values;
}
}