|
Toshihiro Shimizu |
890ddd |
#include <iostream></iostream>
|
|
Toshihiro Shimizu |
890ddd |
#include <iomanip></iomanip>
|
|
Toshihiro Shimizu |
890ddd |
#include <algorithm> /* std::copy() */</algorithm>
|
|
Toshihiro Shimizu |
890ddd |
#include "igs_maxmin_slrender.h"
|
|
Toshihiro Shimizu |
890ddd |
#include "igs_maxmin_lens_matrix.h"
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
void igs::maxmin::slrender::resize(
|
|
Toshihiro Shimizu |
890ddd |
const int odd_diameter, const int width, const bool alpha_ref_sw, std::vector<std::vector<double>> &tracks, std::vector<double> &alpha_ref, std::vector<double> &result)</double></double></std::vector<double>
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
tracks.resize(odd_diameter);
|
|
Toshihiro Shimizu |
890ddd |
for (int yy = 0; yy < odd_diameter; ++yy) {
|
|
Toshihiro Shimizu |
890ddd |
tracks.at(yy).resize(width + odd_diameter - 1);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
if (alpha_ref_sw) {
|
|
Toshihiro Shimizu |
890ddd |
alpha_ref.resize(width);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
result.resize(width);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
void igs::maxmin::slrender::clear(
|
|
Toshihiro Shimizu |
890ddd |
std::vector<std::vector<double>> &tracks, std::vector<double> &alpha_ref, std::vector<double> &result)</double></double></std::vector<double>
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
result.clear();
|
|
Toshihiro Shimizu |
890ddd |
alpha_ref.clear();
|
|
Toshihiro Shimizu |
890ddd |
tracks.clear();
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
void igs::maxmin::slrender::shift(
|
|
Toshihiro Shimizu |
890ddd |
std::vector<std::vector<double>> &tracks)</std::vector<double>
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
/* 先頭からtracks.end()-1番目の要素が先頭にくるように回転 */
|
|
Toshihiro Shimizu |
890ddd |
std::rotate(tracks.begin(), tracks.end() - 1, tracks.end());
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
namespace
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
double maxmin_(
|
|
Toshihiro Shimizu |
890ddd |
const double src, const bool min_sw, const std::vector<const *="" double=""> &begin_ptr, const std::vector<int> &lens_sizes, const std::vector<std::vector<double>> &lens_ratio)</std::vector<double></int></const>
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
if (min_sw) {
|
|
Toshihiro Shimizu |
890ddd |
/* 暗を広げる場合、反転して判断し、結果は反転して戻す */
|
|
Toshihiro Shimizu |
890ddd |
double val = 1.0 - src; /* 反転して判断 */
|
|
Toshihiro Shimizu |
890ddd |
const double rev_src = 1.0 - src; /* 反転して判断 */
|
|
Toshihiro Shimizu |
890ddd |
for (unsigned yy = 0; yy < begin_ptr.size(); ++yy) {
|
|
Toshihiro Shimizu |
890ddd |
const int sz = lens_sizes.at(yy);
|
|
Toshihiro Shimizu |
890ddd |
if (sz <= 0) {
|
|
Toshihiro Shimizu |
890ddd |
continue;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
const double *xptr = begin_ptr.at(yy);
|
|
Toshihiro Shimizu |
890ddd |
const double *rptr = &lens_ratio.at(yy).at(0);
|
|
Toshihiro Shimizu |
890ddd |
for (int xx = 0; xx < sz; ++xx, ++xptr, ++rptr) {
|
|
Toshihiro Shimizu |
890ddd |
double crnt = 1.0 - (*xptr); /* 反転して判断 */
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* 元値と同じか(反転してるので)小さい値は不要 */
|
|
Toshihiro Shimizu |
890ddd |
if (crnt <= rev_src) {
|
|
Toshihiro Shimizu |
890ddd |
continue;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* 元値との差に比率を掛けて結果値を出す */
|
|
Toshihiro Shimizu |
890ddd |
crnt = rev_src + (crnt - rev_src) * (*rptr);
|
|
Toshihiro Shimizu |
890ddd |
/* 今までの中で(反転してるので)より大きいなら代入 */
|
|
Toshihiro Shimizu |
890ddd |
if (val < crnt) {
|
|
Toshihiro Shimizu |
890ddd |
val = crnt;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
return 1.0 - val; /* 結果は反転して戻す */
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
/* Max */
|
|
Toshihiro Shimizu |
890ddd |
double val = src;
|
|
Toshihiro Shimizu |
890ddd |
for (unsigned yy = 0; yy < begin_ptr.size(); ++yy) {
|
|
Toshihiro Shimizu |
890ddd |
const int sz = lens_sizes.at(yy);
|
|
Toshihiro Shimizu |
890ddd |
if (sz <= 0) {
|
|
Toshihiro Shimizu |
890ddd |
continue;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
const double *xptr = begin_ptr.at(yy);
|
|
Toshihiro Shimizu |
890ddd |
const double *rptr = &lens_ratio.at(yy).at(0);
|
|
Toshihiro Shimizu |
890ddd |
for (int xx = 0; xx < sz; ++xx, ++xptr, ++rptr) {
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* 元値と同じか小さい値は不要 */
|
|
Toshihiro Shimizu |
890ddd |
if ((*xptr) <= src) {
|
|
Toshihiro Shimizu |
890ddd |
continue;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* 元値との差に比率を掛けて結果値を出す */
|
|
Toshihiro Shimizu |
890ddd |
const double crnt = src + ((*xptr) - src) * (*rptr);
|
|
Toshihiro Shimizu |
890ddd |
/* 今までの中でより大きいなら代入 */
|
|
Toshihiro Shimizu |
890ddd |
if (val < crnt) {
|
|
Toshihiro Shimizu |
890ddd |
val = crnt;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
return val;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
void set_begin_ptr_(
|
|
Toshihiro Shimizu |
890ddd |
const std::vector<std::vector<double>> &tracks, const std::vector<int> &lens_offsets, const int offset, std::vector<const *="" double=""> &begin_ptr)</const></int></std::vector<double>
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
for (unsigned ii = 0; ii < lens_offsets.size(); ++ii) {
|
|
Toshihiro Shimizu |
890ddd |
begin_ptr.at(ii) =
|
|
Toshihiro Shimizu |
890ddd |
(0 <= lens_offsets.at(ii))
|
|
Toshihiro Shimizu |
890ddd |
? &tracks.at(ii).at(offset + lens_offsets.at(ii))
|
|
Toshihiro Shimizu |
890ddd |
: 0;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
/* --- tracksをレンダリングする --------------------------------------*/
|
|
Toshihiro Shimizu |
890ddd |
void igs::maxmin::slrender::render(
|
|
Toshihiro Shimizu |
890ddd |
const double radius, const double smooth_outer_range, const int polygon_number, const double roll_degree
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
,
|
|
Toshihiro Shimizu |
890ddd |
const bool min_sw
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
,
|
|
Toshihiro Shimizu |
890ddd |
std::vector<int> &lens_offsets, std::vector<int> &lens_sizes, std::vector<std::vector<double>> &lens_ratio</std::vector<double></int></int>
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
,
|
|
Toshihiro Shimizu |
890ddd |
const std::vector<std::vector<double>> &tracks /* RGBのどれか */</std::vector<double>
|
|
Toshihiro Shimizu |
890ddd |
,
|
|
Toshihiro Shimizu |
890ddd |
const std::vector<double> &alpha_ref /* alpha値で影響度合を決める */</double>
|
|
Toshihiro Shimizu |
890ddd |
,
|
|
Toshihiro Shimizu |
890ddd |
std::vector<double> &result /* 計算結果 */</double>
|
|
Toshihiro Shimizu |
890ddd |
)
|
|
Toshihiro Shimizu |
890ddd |
{
|
|
Toshihiro Shimizu |
890ddd |
/* 初期位置 */
|
|
Toshihiro Shimizu |
890ddd |
std::vector<const *="" double=""> begin_ptr(lens_offsets.size());</const>
|
|
Toshihiro Shimizu |
890ddd |
set_begin_ptr_(tracks, lens_offsets, 0, begin_ptr);
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* 効果半径に変化がある場合 */
|
|
Toshihiro Shimizu |
890ddd |
if (0 < alpha_ref.size()) {
|
|
Toshihiro Shimizu |
890ddd |
double before_radius = 0.0;
|
|
Toshihiro Shimizu |
890ddd |
for (unsigned xx = 0; xx < result.size(); ++xx) {
|
|
Toshihiro Shimizu |
890ddd |
/* 次の処理の半径 */
|
|
Toshihiro Shimizu |
890ddd |
const double radius2 = alpha_ref.at(xx) * radius;
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* ゼロ以上なら処理する */
|
|
Toshihiro Shimizu |
890ddd |
if (0.0 < alpha_ref.at(xx)) {
|
|
Toshihiro Shimizu |
890ddd |
/* 前のPixelと違う大きさならreshapeする */
|
|
Toshihiro Shimizu |
890ddd |
if (radius2 != before_radius) {
|
|
Toshihiro Shimizu |
890ddd |
igs::maxmin::reshape_lens_matrix(
|
|
Toshihiro Shimizu |
890ddd |
radius2, igs::maxmin::outer_radius_from_radius(radius2, smooth_outer_range), igs::maxmin::diameter_from_outer_radius(radius + smooth_outer_range), polygon_number, roll_degree, lens_offsets, lens_sizes, lens_ratio);
|
|
Toshihiro Shimizu |
890ddd |
set_begin_ptr_(
|
|
Toshihiro Shimizu |
890ddd |
tracks, lens_offsets, xx, begin_ptr);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
/* 各ピクセルの処理 */
|
|
Toshihiro Shimizu |
890ddd |
result.at(xx) = maxmin_(
|
|
Toshihiro Shimizu |
890ddd |
result.at(xx), min_sw, begin_ptr, lens_sizes, lens_ratio);
|
|
Toshihiro Shimizu |
890ddd |
} /* alpha_refがゼロなら変化なし */
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* 次の位置へ移動 */
|
|
Toshihiro Shimizu |
890ddd |
for (unsigned ii = 0; ii < begin_ptr.size(); ++ii) {
|
|
Toshihiro Shimizu |
890ddd |
if (begin_ptr.at(ii) != 0) {
|
|
Toshihiro Shimizu |
890ddd |
++begin_ptr.at(ii);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
if (radius2 != before_radius) {
|
|
Toshihiro Shimizu |
890ddd |
before_radius = radius2;
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
/* 効果半径が変わらない場合 */
|
|
Toshihiro Shimizu |
890ddd |
else {
|
|
Toshihiro Shimizu |
890ddd |
for (unsigned xx = 0; xx < result.size(); ++xx) {
|
|
Toshihiro Shimizu |
890ddd |
/* 各ピクセルの処理 */
|
|
Toshihiro Shimizu |
890ddd |
result.at(xx) = maxmin_(
|
|
Toshihiro Shimizu |
890ddd |
result.at(xx), min_sw, begin_ptr, lens_sizes, lens_ratio);
|
|
Toshihiro Shimizu |
890ddd |
|
|
Toshihiro Shimizu |
890ddd |
/* 次の位置へ移動 */
|
|
Toshihiro Shimizu |
890ddd |
for (unsigned ii = 0; ii < begin_ptr.size(); ++ii) {
|
|
Toshihiro Shimizu |
890ddd |
if (begin_ptr.at(ii) != 0) {
|
|
Toshihiro Shimizu |
890ddd |
++begin_ptr.at(ii);
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|
|
Toshihiro Shimizu |
890ddd |
}
|