All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.nd4j.tools.BTools Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright (c) 2015-2018 Skymind, Inc.
 *
 * 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.
 *
 * 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
 ******************************************************************************/

package org.nd4j.tools;

import java.text.DecimalFormat;
import java.text.DecimalFormatSymbols;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.Locale;

/**
 * includes several base tools
 *
 * 
 *
 * @author clavvis 
 */

//B = Base
public class BTools {
	//
	
	/**
	 * getMtLvESS
* public static String getMtLvESS( int mtLv )
* Returns string. String length create indentation(shift) of other text.
* Indentation depends on method level - great method level, great indentation.
* Main method has method level 0.
* Other called method has method level 1, 2,...N.
* @param mtLv - method level * @return method level external shift string */ public static String getMtLvESS( int mtLv ) { // MtLvESS = Method Level External Shift String // if ( mtLv < 0 ) return "?"; // String Result = ""; // // String LvS = ". "; String LvS = "."; // for ( int K = 1; K <= mtLv; K ++ ) { // Result = Result + LvS; } // return Result; } /** * getMtLvISS
* public static String getMtLvISS()
* Returns string. String create indentation(shift)
* internal text to start text of method.
* * @return method level internal shift string */ public static String getMtLvISS() { // MtLvISS = Method Level Intern Shift String // // String Result = ".."; // String Result = "~"; String Result = " "; // return Result; } /** * getSpaces
* public static String getSpaces( int SpacesCount )
* Returns asked count of spaces.
* If count of spaces is < 0 returns '?'. * @param SpacesCount = spaces count * @return spaces */ public static String getSpaces( int SpacesCount ) { // if ( SpacesCount < 0 ) return "?"; // String Info = ""; // for ( int K = 1; K <= SpacesCount; K ++ ) { Info += " "; } // // return Info; } /** * getSBln
* public static String getSBln( boolean... blnA )
* Returns boolean(s) converted to char (true = 'T'; false = 'F')
* If blnA.length is > 1 returns chars without separator.
* If blnA is '{ true, false, true }' returns 'TFT'.
* If blnA is null returns '?'.
* If blnA.length is 0 returns '?'.
* @param blnA * @return boolean(s) as string */ public static String getSBln( boolean... blnA ) { // String Info = ""; // if ( blnA == null ) return "?"; if ( blnA.length == 0 ) return "?"; // for ( int K = 0; K < blnA.length; K ++ ) { // Info += ( blnA[ K ] )? "T" : "F"; } // return Info; } /** * getSDbl
* public static String getSDbl( double Value, int DecPrec )
* Returns double converted to string.
* If Value is Double.NaN returns "NaN".
* If DecPrec is < 0 is DecPrec set 0.
* * @param Value - value * @param DecPrec - decimal precision * @return double as string */ public static String getSDbl( double Value, int DecPrec ) { // String Result = ""; // if ( Double.isNaN( Value ) ) return "NaN"; // if ( DecPrec < 0 ) DecPrec = 0; // String DFS = "###,###,##0"; // if ( DecPrec > 0 ) { int idx = 0; DFS += "."; while ( idx < DecPrec ) { DFS = DFS + "0"; idx ++; if ( idx > 100 ) break; } } // // Locale locale = new Locale("en", "UK"); // DecimalFormatSymbols DcmFrmSmb = new DecimalFormatSymbols( Locale.getDefault()); DcmFrmSmb.setDecimalSeparator('.'); DcmFrmSmb.setGroupingSeparator(' '); // DecimalFormat DcmFrm; // DcmFrm = new DecimalFormat( DFS, DcmFrmSmb ); // // DcmFrm.setGroupingSize( 3 ); // Result = DcmFrm.format( Value ); // return Result; } /** * getSDbl
* public static String getSDbl( double Value, int DecPrec, boolean ShowPlusSign )
* Returns double converted to string.
* If Value is Double.NaN returns "NaN".
* If DecPrec is < 0 is DecPrec set 0.
* If ShowPlusSign is true:
* - If Value is > 0 sign is '+'.
* - If Value is 0 sign is ' '.
* @param Value - value * @param DecPrec - decimal precision * @param ShowPlusSign - show plus sign * @return double as string */ public static String getSDbl( double Value, int DecPrec, boolean ShowPlusSign ) { // String PlusSign = ""; // if ( ShowPlusSign && Value > 0 ) PlusSign = "+"; if ( ShowPlusSign && Value == 0 ) PlusSign = " "; // return PlusSign + getSDbl( Value, DecPrec ); } /** * getSDbl
* public static String getSDbl( double Value, int DecPrec, boolean ShowPlusSign, int StringLength )
* Returns double converted to string.
* If Value is Double.NaN returns "NaN".
* If DecPrec is < 0 is DecPrec set 0.
* If ShowPlusSign is true:
* - If Value is > 0 sign is '+'.
* - If Value is 0 sign is ' '.
* If StringLength is > base double string length
* before base double string adds relevant spaces.
* If StringLength is <= base double string length
* returns base double string.
* @param Value - value * @param DecPrec - decimal precision * @param ShowPlusSign - show plus sign * @param StringLength - string length * @return double as string */ public static String getSDbl( double Value, int DecPrec, boolean ShowPlusSign, int StringLength ) { // String Info = ""; // String SDbl = getSDbl( Value, DecPrec, ShowPlusSign ); // if ( SDbl.length() >= StringLength ) return SDbl; // // String SpacesS = " "; String SpacesS = getSpaces( StringLength ); // Info = SpacesS.substring( 0, StringLength - SDbl.length() ) + SDbl; // return Info; } /** * getSInt
* public static String getSInt( int Value, int CharsCount )
* Returns int converted to string.
* If CharsCount > base int string length
* before base int string adds relevant spaces.
* If CharsCount <= base int string length
* returns base int string.
* @param Value - value * @param CharsCount - chars count * @return int as string */ public static String getSInt( int Value, int CharsCount ) { // return getSInt( Value, CharsCount, ' ' ); } /** * getSInt
* public static String getSInt( int Value, int CharsCount, char LeadingChar )
* Returns int converted to string.
* If CharsCount > base int string length
* before base int string adds relevant leading chars.
* If CharsCount <= base int string length
* returns base int string.
* * @param Value - value * @param CharsCount - chars count * @param LeadingChar - leading char * @return int as string */ public static String getSInt( int Value, int CharsCount, char LeadingChar ) { // String Result = ""; // if ( CharsCount <= 0 ) { return getSInt( Value ); } // String FormatS = ""; if ( LeadingChar == '0' ) { FormatS = "%" + LeadingChar + Integer.toString( CharsCount ) + "d"; } else { FormatS = "%" + Integer.toString( CharsCount ) + "d"; } // Result = String.format( FormatS, Value ); // return Result; } /** * getSInt
* public static String getSInt( int Value )
* Returns int converted to string.
* @param Value * @return int as string */ public static String getSInt( int Value ) { // String Result = ""; // Result = String.format( "%d", Value ); // return Result; } /** * getSIntA
* public static String getSIntA( int... intA )
* Returns intA converted to string.
* Strings are separated with ", ".
* If intA is null returns '?'.
* If intA.length is 0 returns '?'.
* @param intA - int value(s) (one or more) * @return int... as string */ // public static String getSIntA( int[] intA ) { public static String getSIntA( int... intA ) { // String Info = ""; // if ( intA == null ) return "?"; if ( intA.length == 0 ) return "?"; // for ( int K = 0; K < intA.length; K ++ ) { // Info += ( Info.isEmpty() )? "" : ", "; Info += BTools.getSInt( intA[ K ] ); } // return Info; } /** * getIndexCharsCount
* public static int getIndexCharsCount( int MaxIndex )
* Returns chars count for max value of index.
* Example: Max value of index is 150 and chars count is 3.
* It is important for statement of indexed values.
* Index columns can have the same width for all rouws.
* @param MaxIndex - max value of index * @return chars count for max value of index */ public static int getIndexCharsCount( int MaxIndex ) { // int CharsCount = 1; // if ( MaxIndex <= 0 ) return 1; // CharsCount = (int)Math.log10( MaxIndex ) + 1; // return CharsCount; } /** * getSLcDtTm
* public static String getSLcDtTm()
* Returns local datetime as string.
* Datetime format is "mm:ss.SSS".
* @return local datetime as string */ public static String getSLcDtTm() { // return getSLcDtTm( "mm:ss.SSS" ); } /** * getSLcDtTm
* public static String getSLcDtTm( String FormatS )
* Returns local datetime as string.
* Datetime format is param.
* @param FormatS datetime format * @return local datetime as string */ public static String getSLcDtTm( String FormatS ) { // String Result = "?"; // LocalDateTime LDT = LocalDateTime.now(); // Result = "LDTm: " + LDT.format( DateTimeFormatter.ofPattern( FormatS ) ); // return Result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy