File: device.fwd.h

package info (click to toggle)
tiny-dnn 1.0.0a3%2Bds-6
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 4,784 kB
  • sloc: cpp: 16,471; ansic: 11,829; lisp: 3,682; python: 3,422; makefile: 208
file content (150 lines) | stat: -rw-r--r-- 5,019 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
/*
    COPYRIGHT

    All contributions by Taiga Nomi
    Copyright (c) 2013, Taiga Nomi
    All rights reserved.

    All other contributions:
    Copyright (c) 2013-2016, the respective contributors.
    All rights reserved.

    Each contributor holds copyright over their respective contributions.
    The project versioning (Git) records all such contribution source information.

    LICENSE

    The BSD 3-Clause License


    Redistribution and use in source and binary forms, with or without
    modification, are permitted provided that the following conditions are met:

    * Redistributions of source code must retain the above copyright notice, this
      list of conditions and the following disclaimer.

    * Redistributions in binary form must reproduce the above copyright notice,
      this list of conditions and the following disclaimer in the documentation
      and/or other materials provided with the distribution.

    * Neither the name of tiny-dnn nor the names of its
      contributors may be used to endorse or promote products derived from
      this software without specific prior written permission.

    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
    AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
    IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
    DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
    FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
    DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
    SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
    CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
    OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
    OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once

#if defined(USE_OPENCL) || defined(USE_CUDA)
#ifdef USE_OPENCL
#include "third_party/CLCudaAPI/clpp11.h"
#else
#include "third_party/CLCudaAPI/cupp11.h"
#endif
#endif

namespace tiny_dnn {

enum class device_t { NONE, CPU, GPU /*, FPGA */ };

inline std::ostream& operator << (std::ostream& os, device_t type) {
    switch (type) {
        case device_t::NONE: os << "NONE"; break;
        case device_t::CPU:  os << "CPU"; break;
        case device_t::GPU:  os << "GPU"; break;
        default:
            throw nn_error("Not supported ostream enum: " +
                    to_string(static_cast<int>(type)));
            break;
    }
    return os;
}

/* The class models a physical device */
class Device {
 public:
    /* Custom CPU constructor
     *
     * @param type The device type. Can be only CPU.
     */
    inline explicit Device(device_t type);

    /* CPU/GPU OpenCL constructor.
     * Device context is initialized in constructor.
     *
     * @param type The device type. Can be both CPU and GPU.
     * @param platform_id The platform identification number.
     * @param device_id The device identification number.
     */
    inline explicit Device(device_t type,
                           const int platform_id,
                           const int device_id);

    // Returns the device type
    device_t type() const { return type_; }

    // Returns true if CLCudaAPI is enabled to this device 
    bool hasCLCudaAPI() const { return has_clcuda_api_; }

    // Returns the platform id
    int platformId() const { return platform_id_; }
    
    // Returns the device id
    int deviceId() const { return device_id_; }

#if defined(USE_OPENCL) || defined(USE_CUDA)
    // Returns the CLCudaAPI Device object
    CLCudaAPI::Device device() const { return *device_;  }

    // Returns the CLCudaAPI Context object
    CLCudaAPI::Context context() const { return *context_; }

    // Returns the CLCudaAPI Queue object
    CLCudaAPI::Queue queue() const { return *queue_; }
#endif

    bool operator==(const Device& d) const {
        if (d.type() == this->type() &&
            d.hasCLCudaAPI() == this->hasCLCudaAPI() &&
            d.platformId() == this->platformId() &&
            d.deviceId() == this->deviceId()) {
            return true;
        }
        return false;
    }

    /* Registers and create an OpenCL program per Operation type.
     *
     * @param l The layer to be registered
     */
    inline void registerOp(layer& l);

 private:
    /* The device type */
    device_t type_;
    /* Boolean to check if device has OpenCL */
    bool has_clcuda_api_;
    /* The platform identification number */
    int platform_id_;
    /* The device identification number */
    int device_id_;
#if defined(USE_OPENCL) || defined(USE_CUDA)
    /* The CLCudaAPI device */
    std::shared_ptr<CLCudaAPI::Device> device_;
    /* The CLCudaAPI device context */
    std::shared_ptr<CLCudaAPI::Context> context_;
    /* The CLCudaAPI device queue */
    std::shared_ptr<CLCudaAPI::Queue> queue_;
#endif
};

}  // namespace tiny_dnn