summaryrefslogtreecommitdiff
path: root/src/ProjectionLSQ.H
blob: d937114ecbeb2ec6c229763c60791f4fa14df9d9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
//
// Copyright 2006 Johannes Hofmann <Johannes.Hofmann@gmx.de>
//
// This software may be used and distributed according to the terms
// of the GNU General Public License, incorporated herein by reference.

#ifndef PROJECTIONLSQ_H
#define PROJECTIONLSQ_H

#include "Hill.H"
#include "ViewParams.H"

class ProjectionLSQ {
	private:
		double comp_scale(double alph_a, double alph_b, double d1, double d2);

		int lsq(const Hills *m, ViewParams *parms, int distortion_correct);

	protected:
		static double pi;
		double sec(double a);

	public:
		typedef enum {
			RECTILINEAR = 0,
			CYLINDRICAL = 1
		} Projection_t;

		ProjectionLSQ();
		virtual ~ProjectionLSQ() {};

		void get_coordinates(double a_view, double a_nick,
			const ViewParams *parms, double *x, double *y);

		int comp_params(const Hills *h, ViewParams *parms);

		virtual double get_view_angle();

#define ARGS double c_view, double c_nick, double c_tilt, double scale, double k0, double k1, double x0, double m_view, double m_nick
		virtual double mac_x(ARGS);
		virtual double mac_y(ARGS);
		virtual double mac_x_dc_view(ARGS);
		virtual double mac_x_dc_nick(ARGS);
		virtual double mac_x_dc_tilt(ARGS);
		virtual double mac_x_dscale(ARGS);
		virtual double mac_x_dk0(ARGS);
		virtual double mac_x_dk1(ARGS);
		virtual double mac_x_dx0(ARGS);
		virtual double mac_y_dc_view(ARGS);
		virtual double mac_y_dc_nick(ARGS);
		virtual double mac_y_dc_tilt(ARGS);
		virtual double mac_y_dscale(ARGS);
		virtual double mac_y_dk0(ARGS);
		virtual double mac_y_dk1(ARGS);
		virtual double mac_y_dx0(ARGS);
#undef ARGS

};
#endif