12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- #ifndef BOOST_GEOMETRY_PROJECTIONS_PJ_INV_HPP
- #define BOOST_GEOMETRY_PROJECTIONS_PJ_INV_HPP
- #include <boost/geometry/srs/projections/impl/adjlon.hpp>
- #include <boost/geometry/core/radian_access.hpp>
- #include <boost/geometry/util/math.hpp>
- namespace boost { namespace geometry { namespace projections
- {
- namespace detail
- {
-
- template <typename PRJ, typename LL, typename XY, typename PAR>
- inline void pj_inv(PRJ const& prj, PAR const& par, XY const& xy, LL& ll)
- {
- typedef typename PAR::type calc_t;
- static const calc_t EPS = 1.0e-12;
-
-
- calc_t lon = 0;
- calc_t lat = 0;
- calc_t xy_x = 0;
- calc_t xy_y = 0;
- if (par.axis[0] == 1)
- {
- xy_x = (geometry::get<1>(xy) * par.to_meter * par.sign[1] - par.x0) * par.ra;
- xy_y = (geometry::get<0>(xy) * par.to_meter * par.sign[0] - par.y0) * par.ra;
- } else {
- xy_x = (geometry::get<0>(xy) * par.to_meter * par.sign[0] - par.x0) * par.ra;
- xy_y = (geometry::get<1>(xy) * par.to_meter * par.sign[1] - par.y0) * par.ra;
- }
- prj.inv(par, xy_x, xy_y, lon, lat);
- lon += par.lam0;
- if (!par.over)
- lon = adjlon(lon);
- if (par.geoc && geometry::math::abs(geometry::math::abs(lat)-geometry::math::half_pi<calc_t>()) > EPS)
- lat = atan(par.one_es * tan(lat));
- geometry::set_from_radian<0>(ll, lon);
- geometry::set_from_radian<1>(ll, lat);
- }
- }
- }}}
- #endif
|