2021-02-09 05:16:31 +01:00
|
|
|
/*
|
|
|
|
* ******************************************************************************
|
|
|
|
* *
|
|
|
|
* *
|
|
|
|
* * This program and the accompanying materials are made available under the
|
|
|
|
* * terms of the Apache License, Version 2.0 which is available at
|
|
|
|
* * https://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
* *
|
|
|
|
* * See the NOTICE file distributed with this work for additional
|
|
|
|
* * information regarding copyright ownership.
|
|
|
|
* * 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.
|
|
|
|
* *
|
|
|
|
* * SPDX-License-Identifier: Apache-2.0
|
|
|
|
* *****************************************************************************
|
|
|
|
*/
|
2019-06-06 14:21:15 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Created by raver119 on 20/04/18.
|
Oleh convert (#200)
* StringUtils for utf convertor raw implementation of all possible combinations, need to be add counter of bytes per symbol for any type and add api to call convertors and store data
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor more corrections to support convertors
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor some corrections and bug fixes, need review to discuss how to add multi-threading
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some corrections to move to multi-threading, add one test need discussion data inputs/outputs array presentation, need discussion the way of multi-threading
* StringUtils for utf convertor #8613 tests added some corrections to optimize build
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some corrections and code clean up
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 code clean up and optimize usage, need update ndarray factory before replace std usage
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some staff to integrate converters into NDArrayFactory, update tests and add some functionality
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 minor corrections and bug fix before discussion
* StringUtils for utf convertor #8613 some fixes and tets
* StringUtils for utf convertor #8613 some more staff to support different unicode
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fix linking bug
* StringUtils for utf convertor #8613 corrected several tests as defaults for string ndarray changed
* StringUtils for utf convertor #8613 replace some incorrect implementation, revert some test changes, need sync before testing
* StringUtils for utf convertor #8613 fixed several thing that were badly implemented yesterday, need optimization, testing (before testing have to be add support of u32 and u16 buffer visualization)
* StringUtils for utf convertor #8613 fixed to support u16 and u32, and convertor in ndarray, fix buffer print, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 merge master and sync with server
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some correction for string cast, need print check only asci support
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 merge master, remove copies and add cast, need test, refactoring according review and clean up
* StringUtils for utf convertor #8613 fixed cast and copy issues
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fixed cuda and update tests
* StringUtils for utf convertor #8613 integration into NdArray, fix several tests for build pass, refactoring, etc
* - avoid ambiguity of NDArray ctrs overloading in some tests
Signed-off-by: Yurii <iuriish@yahoo.com>
* StringUtils for utf convertor #8613 NDArray string constructors added, updated NDArrayFactory, refactoring unicode and tests, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fixed cuda build and test, refactoring and void* added to some functions
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 void* integration, removed copy operation, refactoring, added tests for NDArray string constructors, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 several more fixes, improvements and updates
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 master merge, code clean up and optimization before review
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 minor fixes string element size define
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 revert last changes as mistake
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fixed NDArray constructor build problem, remove order from string factory, fixed order use for factory via project, added catch of incorrect sync in cast of arrays to data types, fixed e method for strings, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 added javacpp hack, added multi-threading, minor corrections in license agreement
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 windows builds fix, as "sting" is not treated as utf8
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
Co-authored-by: Yurii Shyrma <iuriish@yahoo.com>
2020-01-31 14:30:49 +01:00
|
|
|
// @author Oleg Semeniv <oleg.semeniv@gmail.com>
|
2019-06-06 14:21:15 +02:00
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef LIBND4J_STRINGUTILS_H
|
|
|
|
#define LIBND4J_STRINGUTILS_H
|
|
|
|
|
2020-03-02 10:49:41 +01:00
|
|
|
#include <system/pointercast.h>
|
|
|
|
#include <system/op_boilerplate.h>
|
2019-06-06 14:21:15 +02:00
|
|
|
#include <string>
|
|
|
|
#include <sstream>
|
2020-01-04 11:27:50 +01:00
|
|
|
#include <vector>
|
2020-03-02 10:49:41 +01:00
|
|
|
#include <array/NDArray.h>
|
|
|
|
#include <helpers/unicode.h>
|
2019-06-06 14:21:15 +02:00
|
|
|
|
2020-03-02 10:49:41 +01:00
|
|
|
namespace sd {
|
2019-12-02 19:37:21 +01:00
|
|
|
class ND4J_EXPORT StringUtils {
|
2019-06-06 14:21:15 +02:00
|
|
|
public:
|
|
|
|
template <typename T>
|
|
|
|
static FORCEINLINE std::string valueToString(T value) {
|
|
|
|
std::ostringstream os;
|
|
|
|
|
|
|
|
os << value ;
|
|
|
|
|
|
|
|
//convert the string stream into a string and return
|
|
|
|
return os.str();
|
|
|
|
}
|
|
|
|
|
2020-05-30 20:13:33 +02:00
|
|
|
/**
|
|
|
|
* These methods convert integer values to string with 0s and 1s
|
|
|
|
* @param value
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
template <typename T>
|
|
|
|
static std::string bitsToString(T value);
|
|
|
|
|
2019-06-06 14:21:15 +02:00
|
|
|
/**
|
|
|
|
* This method just concatenates error message with a given graphId
|
|
|
|
* @param message
|
|
|
|
* @param graphId
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
static FORCEINLINE std::string buildGraphErrorMessage(const char *message, Nd4jLong graphId) {
|
|
|
|
std::string result(message);
|
|
|
|
result += " [";
|
|
|
|
result += valueToString<Nd4jLong>(graphId);
|
|
|
|
result += "]";
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2020-01-04 11:27:50 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns number of needle matches within haystack
|
|
|
|
* PLEASE NOTE: this method operates on 8-bit arrays interpreted as uint8
|
|
|
|
*
|
|
|
|
* @param haystack
|
|
|
|
* @param haystackLength
|
|
|
|
* @param needle
|
|
|
|
* @param needleLength
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
static uint64_t countSubarrays(const void *haystack, uint64_t haystackLength, const void *needle, uint64_t needleLength);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method returns number of bytes used for string NDArrays content
|
|
|
|
* PLEASE NOTE: this doesn't include header
|
|
|
|
*
|
|
|
|
* @param array
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
static uint64_t byteLength(const NDArray &array);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method splits a string into substring by delimiter
|
|
|
|
*
|
|
|
|
* @param haystack
|
|
|
|
* @param delimiter
|
|
|
|
* @return
|
|
|
|
*/
|
|
|
|
static std::vector<std::string> split(const std::string &haystack, const std::string &delimiter);
|
Oleh convert (#200)
* StringUtils for utf convertor raw implementation of all possible combinations, need to be add counter of bytes per symbol for any type and add api to call convertors and store data
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor more corrections to support convertors
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor some corrections and bug fixes, need review to discuss how to add multi-threading
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some corrections to move to multi-threading, add one test need discussion data inputs/outputs array presentation, need discussion the way of multi-threading
* StringUtils for utf convertor #8613 tests added some corrections to optimize build
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some corrections and code clean up
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 code clean up and optimize usage, need update ndarray factory before replace std usage
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some staff to integrate converters into NDArrayFactory, update tests and add some functionality
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 minor corrections and bug fix before discussion
* StringUtils for utf convertor #8613 some fixes and tets
* StringUtils for utf convertor #8613 some more staff to support different unicode
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fix linking bug
* StringUtils for utf convertor #8613 corrected several tests as defaults for string ndarray changed
* StringUtils for utf convertor #8613 replace some incorrect implementation, revert some test changes, need sync before testing
* StringUtils for utf convertor #8613 fixed several thing that were badly implemented yesterday, need optimization, testing (before testing have to be add support of u32 and u16 buffer visualization)
* StringUtils for utf convertor #8613 fixed to support u16 and u32, and convertor in ndarray, fix buffer print, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 merge master and sync with server
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 some correction for string cast, need print check only asci support
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 merge master, remove copies and add cast, need test, refactoring according review and clean up
* StringUtils for utf convertor #8613 fixed cast and copy issues
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fixed cuda and update tests
* StringUtils for utf convertor #8613 integration into NdArray, fix several tests for build pass, refactoring, etc
* - avoid ambiguity of NDArray ctrs overloading in some tests
Signed-off-by: Yurii <iuriish@yahoo.com>
* StringUtils for utf convertor #8613 NDArray string constructors added, updated NDArrayFactory, refactoring unicode and tests, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fixed cuda build and test, refactoring and void* added to some functions
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 void* integration, removed copy operation, refactoring, added tests for NDArray string constructors, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 several more fixes, improvements and updates
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 master merge, code clean up and optimization before review
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 minor fixes string element size define
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 revert last changes as mistake
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 fixed NDArray constructor build problem, remove order from string factory, fixed order use for factory via project, added catch of incorrect sync in cast of arrays to data types, fixed e method for strings, etc
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 added javacpp hack, added multi-threading, minor corrections in license agreement
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
* StringUtils for utf convertor #8613 windows builds fix, as "sting" is not treated as utf8
Signed-off-by: Oleg <oleg.semeniv@gmail.com>
Co-authored-by: Yurii Shyrma <iuriish@yahoo.com>
2020-01-31 14:30:49 +01:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method convert u8 string to u16
|
|
|
|
* @param const reference to input string
|
|
|
|
* @param reference to output u16string
|
|
|
|
* @return boolean status
|
|
|
|
*/
|
|
|
|
static bool u8StringToU16String(const std::string& u8, std::u16string& u16);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method convert u8 string to u32
|
|
|
|
* @param const reference to input string
|
|
|
|
* @param reference to output u32string
|
|
|
|
* @return boolean status
|
|
|
|
*/
|
|
|
|
static bool u8StringToU32String(const std::string& u8, std::u32string& u32);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method convert u16 string to u32
|
|
|
|
* @param const reference to input u16string
|
|
|
|
* @param reference to output u32string
|
|
|
|
* @return boolean status
|
|
|
|
*/
|
|
|
|
static bool u16StringToU32String(const std::u16string& u16, std::u32string& u32);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method convert u16 string to u8 string
|
|
|
|
* @param const reference to input u16string
|
|
|
|
* @param reference to output string
|
|
|
|
* @return boolean status
|
|
|
|
*/
|
|
|
|
static bool u16StringToU8String(const std::u16string& u16, std::string& u8);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method convert u32 string to u16 string
|
|
|
|
* @param const reference to input u32string
|
|
|
|
* @param reference to output u16string
|
|
|
|
* @return boolean status
|
|
|
|
*/
|
|
|
|
static bool u32StringToU16String(const std::u32string& u32, std::u16string& u16);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method convert u32 string to u8 string
|
|
|
|
* @param const reference to input u32string
|
|
|
|
* @param reference to output string
|
|
|
|
* @return boolean status
|
|
|
|
*/
|
|
|
|
static bool u32StringToU8String(const std::u32string& u32, std::string& u8);
|
2020-05-30 20:13:33 +02:00
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
static std::string vectorToString(const std::vector<T> &vec);
|
2019-06-06 14:21:15 +02:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif //LIBND4J_STRINGUTILS_H
|