"test/infiniop/rope.py" did not exist on "5619c3729d47f7edb968fc12be8e10be1b1955cf"
meta.h 2.52 KB
Newer Older
1
2
3
4
/*!
 * Copyright (c) 2016 Microsoft Corporation. All rights reserved.
 * Licensed under the MIT License. See LICENSE file in the project root for license information.
 */
Guolin Ke's avatar
Guolin Ke committed
5
6
7
8
#ifndef LIGHTGBM_META_H_
#define LIGHTGBM_META_H_

#include <limits>
9
#include <cstdint>
Guolin Ke's avatar
Guolin Ke committed
10
#include <functional>
Guolin Ke's avatar
Guolin Ke committed
11
#include <memory>
12
13
#include <utility>
#include <vector>
Guolin Ke's avatar
Guolin Ke committed
14

15
#if (defined(_MSC_VER) && (defined(_M_IX86) || defined(_M_AMD64))) || defined(__INTEL_COMPILER) || MM_PREFETCH
16
17
18
19
20
21
22
23
  #include <xmmintrin.h>
  #define PREFETCH_T0(addr) _mm_prefetch(reinterpret_cast<const char*>(addr), _MM_HINT_T0)
#elif defined(__GNUC__)
  #define PREFETCH_T0(addr) __builtin_prefetch(reinterpret_cast<const char*>(addr), 0, 3)
#else
  #define PREFETCH_T0(addr) do {} while (0)
#endif

Guolin Ke's avatar
Guolin Ke committed
24
25
26
27
namespace LightGBM {

/*! \brief Type of data size, it is better to use signed type*/
typedef int32_t data_size_t;
28

29
// Enable following macro to use double for score_t
30
31
// #define SCORE_T_USE_DOUBLE

32
// Enable following macro to use double for label_t
33
34
// #define LABEL_T_USE_DOUBLE

35
/*! \brief Type of score, and gradients */
36
37
38
#ifdef SCORE_T_USE_DOUBLE
typedef double score_t;
#else
39
typedef float score_t;
40
41
42
43
44
45
46
47
#endif

/*! \brief Type of metadata, include weight and label */
#ifdef LABEL_T_USE_DOUBLE
typedef double label_t;
#else
typedef float label_t;
#endif
Guolin Ke's avatar
Guolin Ke committed
48

49
const score_t kMinScore = -std::numeric_limits<score_t>::infinity();
Guolin Ke's avatar
Guolin Ke committed
50

51
const score_t kEpsilon = 1e-15f;
Guolin Ke's avatar
Guolin Ke committed
52

Guolin Ke's avatar
Guolin Ke committed
53
const double kZeroThreshold = 1e-35f;
Guolin Ke's avatar
Guolin Ke committed
54

Guolin Ke's avatar
Guolin Ke committed
55
56

typedef int32_t comm_size_t;
Guolin Ke's avatar
Guolin Ke committed
57

Guolin Ke's avatar
Guolin Ke committed
58
using PredictFunction =
Guolin Ke's avatar
Guolin Ke committed
59
std::function<void(const std::vector<std::pair<int, double>>&, double* output)>;
Guolin Ke's avatar
Guolin Ke committed
60

Guolin Ke's avatar
Guolin Ke committed
61
62
63
64
65
66
typedef void(*ReduceFunction)(const char* input, char* output, int type_size, comm_size_t array_size);


typedef void(*ReduceScatterFunction)(char* input, comm_size_t input_size, int type_size,
                                     const comm_size_t* block_start, const comm_size_t* block_len, int num_block, char* output, comm_size_t output_size,
                                     const ReduceFunction& reducer);
ww's avatar
ww committed
67

Guolin Ke's avatar
Guolin Ke committed
68
69
typedef void(*AllgatherFunction)(char* input, comm_size_t input_size, const comm_size_t* block_start,
                                 const comm_size_t* block_len, int num_block, char* output, comm_size_t output_size);
ww's avatar
ww committed
70
71


Guolin Ke's avatar
Guolin Ke committed
72
73
#define NO_SPECIFIC (-1)

74
75
76
const int kAlignedSize = 32;

#define SIZE_ALIGNED(t) ((t) + kAlignedSize - 1) / kAlignedSize * kAlignedSize
77

78
// Refer to https://docs.microsoft.com/en-us/cpp/error-messages/compiler-warnings/compiler-warning-level-4-c4127?view=vs-2019
79
80
81
#ifdef _MSC_VER
  #pragma warning(disable : 4127)
#endif
82

Guolin Ke's avatar
Guolin Ke committed
83
84
}  // namespace LightGBM

85
#endif  // LightGBM_META_H_