summaryrefslogtreecommitdiff
path: root/thirdparty/embree-aarch64/common/math/range.h
blob: 762d9cd9eab50657baae1afa01c49e3e1ac24e62 (plain)
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
// Copyright 2009-2020 Intel Corporation
// SPDX-License-Identifier: Apache-2.0

#pragma once

#include "../sys/platform.h"
#include "../math/math.h"

namespace embree
{
  template<typename Ty>
    struct range 
    {
      __forceinline range() {}

      __forceinline range(const Ty& begin)
        : _begin(begin), _end(begin+1) {}
      
      __forceinline range(const Ty& begin, const Ty& end)
        : _begin(begin), _end(end) {}
 
      __forceinline range(const range& other)
        : _begin(other._begin), _end(other._end) {}

      template<typename T1>
      __forceinline range(const range<T1>& other)
        : _begin(Ty(other._begin)), _end(Ty(other._end)) {}

      template<typename T1>
      __forceinline range& operator =(const range<T1>& other) {
        _begin = other._begin;
        _end = other._end;
        return *this;
      }
      
      __forceinline Ty begin() const {
        return _begin;
      }
      
      __forceinline Ty end() const {
	return _end;
      }

      __forceinline range intersect(const range& r) const {
        return range (max(_begin,r._begin),min(_end,r._end));
      }

      __forceinline Ty size() const {
        return _end - _begin;
      }

      __forceinline bool empty() const { 
        return _end <= _begin; 
      }

      __forceinline Ty center() const {
        return (_begin + _end)/2;
      }

      __forceinline std::pair<range,range> split() const 
      {
        const Ty _center = center();
        return std::make_pair(range(_begin,_center),range(_center,_end));
      }

      __forceinline void split(range& left_o, range& right_o) const 
      {
        const Ty _center = center();
        left_o = range(_begin,_center);
        right_o = range(_center,_end);
      }

      __forceinline friend bool operator< (const range& r0, const range& r1) {
        return r0.size() < r1.size();
      }
	
      friend embree_ostream operator<<(embree_ostream cout, const range& r) {
        return cout << "range [" << r.begin() << ", " << r.end() << "]";
      }
      
      Ty _begin, _end;
    };

  template<typename Ty>
    range<Ty> make_range(const Ty& begin, const Ty& end) {
    return range<Ty>(begin,end);
  }

  template<typename Ty>
    struct extended_range : public range<Ty>
    {
      __forceinline extended_range () {}

      __forceinline extended_range (const Ty& begin)
        : range<Ty>(begin), _ext_end(begin+1) {}
      
      __forceinline extended_range (const Ty& begin, const Ty& end)
        : range<Ty>(begin,end), _ext_end(end) {}

      __forceinline extended_range (const Ty& begin, const Ty& end, const Ty& ext_end)
        : range<Ty>(begin,end), _ext_end(ext_end) {}
      
      __forceinline Ty ext_end() const {
	return _ext_end;
      }

      __forceinline Ty ext_size() const {
        return _ext_end - range<Ty>::_begin;
      }

      __forceinline Ty ext_range_size() const {
        return _ext_end - range<Ty>::_end;
      }

      __forceinline bool has_ext_range() const {
        assert(_ext_end >= range<Ty>::_end);
        return (_ext_end - range<Ty>::_end) > 0;
      }

      __forceinline void set_ext_range(const size_t ext_end){
        assert(ext_end >= range<Ty>::_end);
        _ext_end = ext_end;
      }

      __forceinline void move_right(const size_t plus){
        range<Ty>::_begin   += plus;
        range<Ty>::_end     += plus;
        _ext_end += plus;
      }

      friend embree_ostream operator<<(embree_ostream cout, const extended_range& r) {
        return cout << "extended_range [" << r.begin() << ", " << r.end() <<  " (" << r.ext_end() << ")]";
      }
      
      Ty _ext_end;
    };
}