Blob Blame Raw
#pragma once

#ifndef igs_maxmin_lens_matrix_h
#define igs_maxmin_lens_matrix_h

#include <vector>

namespace igs
{
namespace maxmin
{
const int diameter_from_outer_radius(
	const double outer_radius);
const double outer_radius_from_radius(
	const double radius, const double smooth_outer_range);
const int alloc_and_shape_lens_matrix(
	const double radius // 0=<
	,
	const double outer_radius, const int polygon_number // =2
	,
	const double roll_degree // 0<= ... <=360
	,
	std::vector<int> &lens_offsets, std::vector<int> &lens_sizes, std::vector<std::vector<double>> &lens_ratio);
/*
	lens_offsetsとlens_sizesで影響範囲を表わすmatrixを表わす
	radiusは影響円の半径
	matrix(縦横)サイズ(lens_offsets.size())は
		円(radius)が入る最小整数値でかつ、
		1以上の奇数(1,3,5,6)値
  */
const void reshape_lens_matrix(
	const double radius // 0<=
	,
	const double outer_radius, const int odd_diameter, const int polygon_number // =2
	,
	const double roll_degree // 0<= ... <=360
	,
	std::vector<int> &lens_offsets, std::vector<int> &lens_sizes, std::vector<std::vector<double>> &lens_ratio);
}
}

#endif /* !igs_maxmin_lens_matrix_h */