openspades/Sources/Draw/SWUtils.h

88 lines
2.3 KiB
C
Raw Normal View History

2013-12-23 19:46:56 +09:00
/*
Copyright (c) 2013 yvt
This file is part of OpenSpades.
OpenSpades is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
OpenSpades is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with OpenSpades. If not, see <http://www.gnu.org/licenses/>.
*/
#pragma once
#include <algorithm>
#include <Core/ConcurrentDispatch.h>
#include <Core/Debug.h>
#include <Core/Settings.h>
2013-12-24 16:23:36 +09:00
#include <array>
2013-12-25 09:57:47 +01:00
#include <memory>
2013-12-23 19:46:56 +09:00
namespace spades {
namespace draw {
SPADES_SETTING(r_swNumThreads, "");
template <class F>
static void InvokeParallel(F f, unsigned int numThreads) {
SPAssert(numThreads <= 32);
std::array<std::unique_ptr<ConcurrentDispatch>, 32> disp;
for(auto i = 1U; i < numThreads; i++) {
auto ff = [i, &f]() {
f(i);
};
disp[i] = std::unique_ptr<ConcurrentDispatch>
(static_cast<ConcurrentDispatch *>(new FunctionDispatch<decltype(ff)>(ff)));
disp[i]->Start();
}
f(0);
for(auto i = 1U; i < numThreads; i++) {
disp[i]->Join();
}
}
template <class F>
static void InvokeParallel2(F f) {
unsigned int numThreads = static_cast<unsigned int>((int)r_swNumThreads);
numThreads = std::max(numThreads, 1U);
numThreads = std::min(numThreads, 32U);
std::array<std::unique_ptr<ConcurrentDispatch>, 32> disp;
for(auto i = 1U; i < numThreads; i++) {
auto ff = [i, &f, numThreads]() {
f(i, numThreads);
};
disp[i] = std::unique_ptr<ConcurrentDispatch>
(static_cast<ConcurrentDispatch *>(new FunctionDispatch<decltype(ff)>(ff)));
disp[i]->Start();
}
f(0, numThreads);
for(auto i = 1U; i < numThreads; i++) {
disp[i]->Join();
}
}
static inline int ToFixed8(float v) {
int i = static_cast<int>(v * 255.f + .5f);
return std::max(std::min(i, 255), 0);
}
static inline int ToFixedFactor8(float v) {
int i = static_cast<int>(v * 256.f + .5f);
return std::max(std::min(i, 256), 0);
}
2013-12-23 19:46:56 +09:00
}
}