/*
* Encog(tm) Core v3.4 - Java Version
* http://www.heatonresearch.com/encog/
* https://github.com/encog/encog-java-core
* Copyright 2008-2016 Heaton Research, Inc.
*
* 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.
*
* For more information on Heaton Research copyrights, licenses
* and trademarks visit:
* http://www.heatonresearch.com/copyright
*/
package org.encog.util.text;
import java.io.UnsupportedEncodingException;
import org.encog.Encog;
import org.encog.EncogError;
public class DoubleString {
public final static double FRAC_SHIFT = 100000000.0;
public final static int[] MULT = { 0x10000, 0x100, 0x01 };
public static String convertDoubleToString(double[] target, int index) {
boolean wholeMode = true;
int currentIndex = index;
int multIndex = 0;
int len = (int)target[currentIndex];
int encodedLen = (int)((target[currentIndex]-len) * FRAC_SHIFT);
byte[] encoded = new byte[encodedLen];
currentIndex++;
int assembled = (int)target[currentIndex];
for(int i=0;i<encoded.length;i++) {
encoded[i] = (byte)(assembled/MULT[multIndex]);
assembled-=target[currentIndex]*MULT[multIndex];
multIndex++;
if(multIndex==MULT.length) {
multIndex=0;
if( wholeMode ) {
double dec = (encoded[currentIndex] - ((int)encoded[currentIndex]));
assembled = (int)(dec * FRAC_SHIFT);
wholeMode = false;
} else {
wholeMode = true;
assembled = (int)target[currentIndex++];
}
}
}
try {
return new String(encoded, Encog.DEFAULT_ENCODING);
} catch (UnsupportedEncodingException e) {
throw new EncogError(e);
}
}
public static int convertStringToDouble(String str, double[] target, int targetIndex) {
try {
int multIndex = 0;
int assemble = 0;
boolean wholeMode = true;
byte[] encoded = str.getBytes(Encog.DEFAULT_ENCODING);
int outputIndex = targetIndex;
int len = (encoded.length/6);
if( (encoded.length%6)>0 ) {
len++;
}
target[outputIndex++] = (encoded.length/FRAC_SHIFT) + len;
for(int i=0;i<encoded.length;i++) {
assemble+=encoded[i]*MULT[multIndex++];
if( multIndex>=3 ) {
if( wholeMode ) {
target[outputIndex] = assemble;
} else {
target[outputIndex++] += assemble/FRAC_SHIFT;
}
multIndex = 0;
wholeMode=!wholeMode;
assemble = 0;
}
}
if( wholeMode ) {
target[outputIndex] = assemble;
} else {
target[outputIndex++] += assemble/FRAC_SHIFT;
}
return (outputIndex - targetIndex)+1;
} catch (UnsupportedEncodingException e) {
throw new EncogError(e);
}
}
public static void main(String[] args) {
String str = "This is a test";
double[] target = new double[1024];
int len = DoubleString.convertStringToDouble(str, target, 0);
for(int i=0;i<len;i++) {
System.out.println(target[i]);
}
System.out.println(DoubleString.convertDoubleToString(target, 0));
}
}