GeographicLib: AlbersEqualArea.hpp Source File (original) (raw)

61 private:

63 real eps_, epsx_, epsx2_, tol_, tol0_;

64 real _a, _f, _fm, _e2, _e, _e2m, _qZ, _qx;

65 real _sign, _lat0, _k0;

66 real _n0, _m02, _nrho0, _k2, _txi0, _scxi0, _sxi0;

67 static const int numit_ = 5;

68 static const int numit0_ = 20;

69 static real hyp(real x) {

70 using std::hypot;

71 return hypot(real(1), x);

72 }

73

74

75

76 real atanhee(real x) const {

77 using std::atan; using std::atanh;

78 return _f > 0 ? atanh(_e * x)/_e : (_f < 0 ? (atan(_e * x)/_e) : x);

79 }

80

81 static real atanhxm1(real x);

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100 static real Dsn(real x, real y, real sx, real sy) {

101

102 real t = x * y;

103 return t > 0 ? (x + y) * Math::sq( (sx * sy)/t ) / (sx + sy) :

104 (x - y != 0 ? (sx - sy) / (x - y) : 1);

105 }

106

107

108 real Datanhee(real x, real y) const {

109 real t = x - y, d = 1 - _e2 * x * y;

110 return t == 0 ? 1 / d :

111 (x*y < 0 ? atanhee(x) - atanhee(y) : atanhee(t / d)) / t;

112 }

113

114 real DDatanhee(real x, real y) const;

115 real DDatanhee0(real x, real y) const;

116 real DDatanhee1(real x, real y) const;

117 real DDatanhee2(real x, real y) const;

118 void Init(real sphi1, real cphi1, real sphi2, real cphi2, real k1);

119 real txif(real tphi) const;

120 real tphif(real txi) const;

121 public:

122

123

124

125

126

127

128

129

130

131

132

133

134

135

137

138

139

140

141

142

143

144

145

146

147

148

149

150

151

152

153 AlbersEqualArea(real a, real f, real stdlat1, real stdlat2, real k1);

154

155

156

157

158

159

160

161

162

163

164

165

166

167

168

169

170

171

172

173

174

175

176

177

179 real sinlat1, real coslat1,

180 real sinlat2, real coslat2,

181 real k1);

182

183

184

185

186

187

188

189

190

191

192

193

194 void SetScale(real lat, real k = real(1));

195

196

197

198

199

200

201

202

203

204

205

206

207

208

209

210

211

212

213

214 void Forward(real lon0, real lat, real lon,

215 real& x, real& y, real& gamma, real& k) const;

216

217

218

219

220

221

222

223

224

225

226

227

228

229

230

231

232

233

234

235 void Reverse(real lon0, real x, real y,

236 real& lat, real& lon, real& gamma, real& k) const;

237

238

239

240

241

242 void Forward(real lon0, real lat, real lon,

243 real& x, real& y) const {

244 real gamma, k;

245 Forward(lon0, lat, lon, x, y, gamma, k);

246 }

247

248

249

250

251

252 void Reverse(real lon0, real x, real y,

253 real& lat, real& lon) const {

254 real gamma, k;

255 Reverse(lon0, x, y, lat, lon, gamma, k);

256 }

257

258

259

260

261

262

263

264

266

267

268

269

270

272

273

274

275

276

277

278

279

281

282

283

284

285

287

288

289

290

291

292

293

295

296

297

298

299

300

302

303

304

305

306

307

309 };