#include <unistd.h>
#include <cstdlib>
#include <cstdio>
#include "CoinError.hpp"
#include "CoinFinite.hpp"
Include dependency graph for CoinHelperFunctions.hpp:
This graph shows which files directly or indirectly include this file:
Go to the source code of this file.
Classes | |
class | CoinThreadRandom |
Class for thread specific random numbers. More... | |
Defines | |
#define | COIN_OWN_RANDOM_32 |
#define | CoinSizeofAsInt(type) (static_cast<int>(sizeof(type))) |
This helper returns "sizeof" as an int. | |
Functions | |
template<class T> | |
void | CoinCopyN (register const T *from, const int size, register T *to) |
This helper function copies an array to another location using Duff's device (for a speedup of ~2). | |
template<class T> | |
void | CoinCopy (register const T *first, register const T *last, register T *to) |
This helper function copies an array to another location using Duff's device (for a speedup of ~2). | |
template<class T> | |
void | CoinDisjointCopyN (register const T *from, const int size, register T *to) |
This helper function copies an array to another location. | |
template<class T> | |
void | CoinDisjointCopy (register const T *first, register const T *last, register T *to) |
This helper function copies an array to another location. | |
template<class T> | |
T * | CoinCopyOfArray (const T *array, const int size) |
Return an array of length size filled with input from array , or null if array is null. | |
template<class T> | |
T * | CoinCopyOfArrayPartial (const T *array, const int size, const int copySize) |
Return an array of length size filled with first copySize from array , or null if array is null. | |
template<class T> | |
T * | CoinCopyOfArray (const T *array, const int size, T value) |
Return an array of length size filled with input from array , or filled with (scalar) value if array is null. | |
template<class T> | |
T * | CoinCopyOfArrayOrZero (const T *array, const int size) |
Return an array of length size filled with input from array , or filled with zero if array is null. | |
template<class T> | |
void | CoinMemcpyN (register const T *from, const int size, register T *to) |
This helper function copies an array to another location. | |
template<class T> | |
void | CoinMemcpy (register const T *first, register const T *last, register T *to) |
This helper function copies an array to another location. | |
template<class T> | |
void | CoinFillN (register T *to, const int size, register const T value) |
This helper function fills an array with a given value. | |
template<class T> | |
void | CoinFill (register T *first, register T *last, const T value) |
This helper function fills an array with a given value. | |
template<class T> | |
void | CoinZeroN (register T *to, const int size) |
This helper function fills an array with zero. | |
void | CoinCheckDoubleZero (double *to, const int size) |
This Debug helper function checks an array is all zero. | |
void | CoinCheckIntZero (int *to, const int size) |
This Debug helper function checks an array is all zero. | |
template<class T> | |
void | CoinZero (register T *first, register T *last) |
This helper function fills an array with a given value. | |
char * | CoinStrdup (const char *name) |
Returns strdup or NULL if original NULL. | |
template<class T> | |
T | CoinMax (register const T x1, register const T x2) |
Return the larger (according to operator<() of the arguments. | |
template<class T> | |
T | CoinMin (register const T x1, register const T x2) |
Return the smaller (according to operator<() of the arguments. | |
template<class T> | |
T | CoinAbs (const T value) |
Return the absolute value of the argument. | |
template<class T> | |
bool | CoinIsSorted (register const T *first, const int size) |
This helper function tests whether the entries of an array are sorted according to operator<. | |
template<class T> | |
bool | CoinIsSorted (register const T *first, register const T *last) |
This helper function tests whether the entries of an array are sorted according to operator<. | |
template<class T> | |
void | CoinIotaN (register T *first, const int size, register T init) |
This helper function fills an array with the values init, init+1, init+2, etc. | |
template<class T> | |
void | CoinIota (T *first, const T *last, T init) |
This helper function fills an array with the values init, init+1, init+2, etc. | |
template<class T> | |
T * | CoinDeleteEntriesFromArray (register T *arrayFirst, register T *arrayLast, const int *firstDelPos, const int *lastDelPos) |
This helper function deletes certain entries from an array. | |
double | CoinDrand48 (bool isSeed=false, unsigned int seed=1) |
Return random number between 0 and 1. | |
void | CoinSeedRandom (int iseed) |
Seed random number generator. | |
char | CoinFindDirSeparator () |
This function figures out whether file names should contain slashes or backslashes as directory separator. | |
int | CoinStrNCaseCmp (const char *s0, const char *s1, const size_t len) |
template<class T> | |
void | CoinSwap (T &x, T &y) |
Swap the arguments. | |
template<class T> | |
int | CoinToFile (const T *array, CoinBigIndex size, FILE *fp) |
This helper function copies an array to file Returns 0 if OK, 1 if bad write. | |
template<class T> | |
int | CoinFromFile (T *&array, CoinBigIndex size, FILE *fp, CoinBigIndex &newSize) |
This helper function copies an array from file and creates with new. | |
double | CoinCbrt (double x) |
Cube Root. | |
int | CoinStrlenAsInt (const char *string) |
This helper returns "strlen" as an int. |
#define COIN_OWN_RANDOM_32 |
Definition at line 738 of file CoinHelperFunctions.hpp.
#define CoinSizeofAsInt | ( | type | ) | (static_cast<int>(sizeof(type))) |
This helper returns "sizeof" as an int.
Definition at line 910 of file CoinHelperFunctions.hpp.
Referenced by CoinBigIndexArrayWithLength::CoinBigIndexArrayWithLength(), CoinDoubleArrayWithLength::CoinDoubleArrayWithLength(), CoinFactorizationDoubleArrayWithLength::CoinFactorizationDoubleArrayWithLength(), CoinIntArrayWithLength::CoinIntArrayWithLength(), CoinUnsignedIntArrayWithLength::CoinUnsignedIntArrayWithLength(), CoinUnsignedIntArrayWithLength::conditionalNew(), CoinBigIndexArrayWithLength::conditionalNew(), CoinIntArrayWithLength::conditionalNew(), CoinFactorizationDoubleArrayWithLength::conditionalNew(), CoinDoubleArrayWithLength::conditionalNew(), CoinUnsignedIntArrayWithLength::getSize(), CoinBigIndexArrayWithLength::getSize(), CoinIntArrayWithLength::getSize(), CoinFactorizationDoubleArrayWithLength::getSize(), CoinDoubleArrayWithLength::getSize(), CoinUnsignedIntArrayWithLength::setSize(), CoinBigIndexArrayWithLength::setSize(), CoinIntArrayWithLength::setSize(), CoinFactorizationDoubleArrayWithLength::setSize(), and CoinDoubleArrayWithLength::setSize().
void CoinCopyN | ( | register const T * | from, | |
const int | size, | |||
register T * | to | |||
) | [inline] |
This helper function copies an array to another location using Duff's device (for a speedup of ~2).
The arrays are given by pointers to their first entries and by the size of the source array. Overlapping arrays are handled correctly.
Definition at line 27 of file CoinHelperFunctions.hpp.
Referenced by CoinCopy(), CoinDisjointCopyN(), CoinMemcpyN(), AbcNodeDesc::setLowerBounds(), and AbcNodeDesc::setUpperBounds().
void CoinCopy | ( | register const T * | first, | |
register const T * | last, | |||
register T * | to | |||
) | [inline] |
This helper function copies an array to another location using Duff's device (for a speedup of ~2).
The source array is given by its first and "after last" entry; the target array is given by its first entry. Overlapping arrays are handled correctly.
All of the various CoinCopyN variants use an int for size. On 64-bit architectures, the address diff last-first will be a 64-bit quantity. Given that everything else uses an int, I'm going to choose to kick the difference down to int. -- lh, 100823 --
Definition at line 85 of file CoinHelperFunctions.hpp.
References CoinCopyN().
Referenced by CoinDeleteEntriesFromArray().
void CoinDisjointCopyN | ( | register const T * | from, | |
const int | size, | |||
register T * | to | |||
) | [inline] |
This helper function copies an array to another location.
The two arrays must not overlap (otherwise an exception is thrown). For speed 8 entries are copied at a time. The arrays are given by pointers to their first entries and by the size of the source array.
Note JJF - the speed claim seems to be false on IA32 so I have added CoinMemcpyN which can be used for atomic data
Definition at line 100 of file CoinHelperFunctions.hpp.
References CoinCopyN().
Referenced by CoinDisjointCopy(), CoinTreeSiblings::CoinTreeSiblings(), CoinWarmStartVector< U >::CoinWarmStartVector(), and CoinWarmStartVector< U >::gutsOfCopy().
void CoinDisjointCopy | ( | register const T * | first, | |
register const T * | last, | |||
register T * | to | |||
) | [inline] |
This helper function copies an array to another location.
The two arrays must not overlap (otherwise an exception is thrown). For speed 8 entries are copied at a time. The source array is given by its first and "after last" entry; the target array is given by its first entry.
Definition at line 153 of file CoinHelperFunctions.hpp.
References CoinDisjointCopyN().
Referenced by CoinDeleteEntriesFromArray().
T* CoinCopyOfArray | ( | const T * | array, | |
const int | size | |||
) | [inline] |
Return an array of length size
filled with input from array
, or null if array
is null.
Definition at line 166 of file CoinHelperFunctions.hpp.
T* CoinCopyOfArrayPartial | ( | const T * | array, | |
const int | size, | |||
const int | copySize | |||
) | [inline] |
Return an array of length size
filled with first copySize from array
, or null if array
is null.
Definition at line 183 of file CoinHelperFunctions.hpp.
T* CoinCopyOfArray | ( | const T * | array, | |
const int | size, | |||
T | value | |||
) | [inline] |
Return an array of length size
filled with input from array
, or filled with (scalar) value
if array
is null.
Definition at line 200 of file CoinHelperFunctions.hpp.
T* CoinCopyOfArrayOrZero | ( | const T * | array, | |
const int | size | |||
) | [inline] |
Return an array of length size
filled with input from array
, or filled with zero if array
is null.
Definition at line 219 of file CoinHelperFunctions.hpp.
void CoinMemcpyN | ( | register const T * | from, | |
const int | size, | |||
register T * | to | |||
) | [inline] |
This helper function copies an array to another location.
The two arrays must not overlap (otherwise an exception is thrown). For speed 8 entries are copied at a time. The arrays are given by pointers to their first entries and by the size of the source array.
Note JJF - the speed claim seems to be false on IA32 so I have added alternative coding if USE_MEMCPY defined
Definition at line 242 of file CoinHelperFunctions.hpp.
References CoinCopyN().
Referenced by c_ekkdcpy(), c_ekkscpy(), CoinMemcpy(), and CoinStrdup().
void CoinMemcpy | ( | register const T * | first, | |
register const T * | last, | |||
register T * | to | |||
) | [inline] |
This helper function copies an array to another location.
The two arrays must not overlap (otherwise an exception is thrown). For speed 8 entries are copied at a time. The source array is given by its first and "after last" entry; the target array is given by its first entry.
Definition at line 329 of file CoinHelperFunctions.hpp.
References CoinMemcpyN().
void CoinFillN | ( | register T * | to, | |
const int | size, | |||
register const T | value | |||
) | [inline] |
This helper function fills an array with a given value.
For speed 8 entries are filled at a time. The array is given by a pointer to its first entry and its size.
Note JJF - the speed claim seems to be false on IA32 so I have added CoinZero to allow for memset.
Definition at line 344 of file CoinHelperFunctions.hpp.
Referenced by CoinFill().
void CoinFill | ( | register T * | first, | |
register T * | last, | |||
const T | value | |||
) | [inline] |
This helper function fills an array with a given value.
For speed 8 entries are filled at a time. The array is given by its first and "after last" entry.
Definition at line 399 of file CoinHelperFunctions.hpp.
References CoinFillN().
void CoinZeroN | ( | register T * | to, | |
const int | size | |||
) | [inline] |
This helper function fills an array with zero.
For speed 8 entries are filled at a time. The array is given by a pointer to its first entry and its size.
Note JJF - the speed claim seems to be false on IA32 so I have allowed for memset as an alternative
Definition at line 413 of file CoinHelperFunctions.hpp.
Referenced by c_ekkczero(), c_ekkdzero(), c_ekkizero(), and CoinZero().
void CoinCheckDoubleZero | ( | double * | to, | |
const int | size | |||
) | [inline] |
This Debug helper function checks an array is all zero.
Definition at line 474 of file CoinHelperFunctions.hpp.
void CoinCheckIntZero | ( | int * | to, | |
const int | size | |||
) | [inline] |
This Debug helper function checks an array is all zero.
Definition at line 487 of file CoinHelperFunctions.hpp.
void CoinZero | ( | register T * | first, | |
register T * | last | |||
) | [inline] |
This helper function fills an array with a given value.
For speed 8 entries are filled at a time. The array is given by its first and "after last" entry.
Definition at line 505 of file CoinHelperFunctions.hpp.
References CoinZeroN().
char* CoinStrdup | ( | const char * | name | ) | [inline] |
Returns strdup or NULL if original NULL.
Definition at line 513 of file CoinHelperFunctions.hpp.
References CoinMemcpyN().
T CoinMax | ( | register const T | x1, | |
register const T | x2 | |||
) | [inline] |
Return the larger (according to operator<()
of the arguments.
This function was introduced because for some reason compiler tend to handle the max()
function differently.
Definition at line 531 of file CoinHelperFunctions.hpp.
Referenced by CoinDenseVector< T >::infNorm().
T CoinMin | ( | register const T | x1, | |
register const T | x2 | |||
) | [inline] |
Return the smaller (according to operator<()
of the arguments.
This function was introduced because for some reason compiler tend to handle the min() function differently.
Definition at line 542 of file CoinHelperFunctions.hpp.
T CoinAbs | ( | const T | value | ) | [inline] |
Return the absolute value of the argument.
This function was introduced because for some reason compiler tend to handle the abs() function differently.
Definition at line 553 of file CoinHelperFunctions.hpp.
Referenced by CoinDenseVector< T >::infNorm(), and CoinDenseVector< T >::oneNorm().
bool CoinIsSorted | ( | register const T * | first, | |
const int | size | |||
) | [inline] |
This helper function tests whether the entries of an array are sorted according to operator<.
The array is given by a pointer to its first entry and by its size.
Definition at line 564 of file CoinHelperFunctions.hpp.
Referenced by CoinDeleteEntriesFromArray(), and CoinIsSorted().
bool CoinIsSorted | ( | register const T * | first, | |
register const T * | last | |||
) | [inline] |
This helper function tests whether the entries of an array are sorted according to operator<.
The array is given by its first and "after last" entry.
Definition at line 613 of file CoinHelperFunctions.hpp.
References CoinIsSorted().
void CoinIotaN | ( | register T * | first, | |
const int | size, | |||
register T | init | |||
) | [inline] |
This helper function fills an array with the values init, init+1, init+2, etc.
For speed 8 entries are filled at a time. The array is given by a pointer to its first entry and its size.
Definition at line 624 of file CoinHelperFunctions.hpp.
Referenced by CoinIota().
void CoinIota | ( | T * | first, | |
const T * | last, | |||
T | init | |||
) | [inline] |
This helper function fills an array with the values init, init+1, init+2, etc.
For speed 8 entries are filled at a time. The array is given by its first and "after last" entry.
Definition at line 679 of file CoinHelperFunctions.hpp.
References CoinIotaN().
T* CoinDeleteEntriesFromArray | ( | register T * | arrayFirst, | |
register T * | arrayLast, | |||
const int * | firstDelPos, | |||
const int * | lastDelPos | |||
) | [inline] |
This helper function deletes certain entries from an array.
The array is given by pointers to its first and "after last" entry (first two arguments). The positions of the entries to be deleted are given in the integer array specified by the last two arguments (again, first and "after last" entry).
Definition at line 692 of file CoinHelperFunctions.hpp.
References CoinCopy(), CoinDisjointCopy(), and CoinIsSorted().
double CoinDrand48 | ( | bool | isSeed = false , |
|
unsigned int | seed = 1 | |||
) | [inline] |
Return random number between 0 and 1.
Definition at line 749 of file CoinHelperFunctions.hpp.
Referenced by CoinSeedRandom().
void CoinSeedRandom | ( | int | iseed | ) | [inline] |
Seed random number generator.
Definition at line 761 of file CoinHelperFunctions.hpp.
References CoinDrand48().
char CoinFindDirSeparator | ( | ) | [inline] |
This function figures out whether file names should contain slashes or backslashes as directory separator.
Definition at line 786 of file CoinHelperFunctions.hpp.
int CoinStrNCaseCmp | ( | const char * | s0, | |
const char * | s1, | |||
const size_t | len | |||
) | [inline] |
Definition at line 806 of file CoinHelperFunctions.hpp.
void CoinSwap | ( | T & | x, | |
T & | y | |||
) | [inline] |
int CoinToFile | ( | const T * | array, | |
CoinBigIndex | size, | |||
FILE * | fp | |||
) | [inline] |
This helper function copies an array to file Returns 0 if OK, 1 if bad write.
Definition at line 843 of file CoinHelperFunctions.hpp.
int CoinFromFile | ( | T *& | array, | |
CoinBigIndex | size, | |||
FILE * | fp, | |||
CoinBigIndex & | newSize | |||
) | [inline] |
This helper function copies an array from file and creates with new.
Passed in array is ignored i.e. not deleted. But if NULL and size does not match and newSize 0 then leaves as NULL and 0 Returns 0 if OK, 1 if bad read, 2 if size did not match.
Definition at line 874 of file CoinHelperFunctions.hpp.
double CoinCbrt | ( | double | x | ) | [inline] |
int CoinStrlenAsInt | ( | const char * | string | ) | [inline] |