aboutsummaryrefslogtreecommitdiff
path: root/pkg/xtools/gtools/gtascale.x
blob: 06f5c0ef6ad9e9fcc8689c9e45ed9aa071f887e1 (plain) (blame)
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
# Copyright(c) 1986 Association of Universities for Research in Astronomy Inc.

include <mach.h>
include	"gtools.h"
	
# GT_ASCALE -- Set graphics window to the range of the data.
# Unlike GASCALE the data is limited to the GTOOLS window.
# It also clips a fraction of the high and low points.

procedure gt_ascale (gp, gt, x, y, npts)

pointer	gp			# GIO pointer
pointer	gt			# GTOOLS pointer
real	x[npts], y[npts]	# Data to scale
int	npts			# Number of data points

int	i, j, k, n
real	xmin, xmax, ymin, ymax, x1, x2, y1, y2, temp
pointer	buf

begin
	if (gt == NULL) {
	    call gascale (gp, x, npts, 1)
	    call gascale (gp, y, npts, 1)
	    return
	}

	if (GT_TRANSPOSE(gt) == NO) {
	    xmin = GT_XMIN(gt)
	    xmax = GT_XMAX(gt)
	    ymin = GT_YMIN(gt)
	    ymax = GT_YMAX(gt)
	} else {
	    ymin = GT_XMIN(gt)
	    ymax = GT_XMAX(gt)
	    xmin = GT_YMIN(gt)
	    xmax = GT_YMAX(gt)
	}

	if (IS_INDEF(xmin))
	    xmin = -MAX_REAL
	if (IS_INDEF(xmax))
	    xmax = MAX_REAL
	if (IS_INDEF(ymin))
	    ymin = -MAX_REAL
	if (IS_INDEF(ymax))
	    ymax = MAX_REAL

	temp = max (xmin, xmax)
	xmin = min (xmin, xmax)
	xmax = temp
	temp = max (ymin, ymax)
	ymin = min (ymin, ymax)
	ymax = temp

	x1 = xmax
	x2 = xmin
	y1 = ymax
	y2 = ymin
	n = 0
	do i = 1, npts {
	    if ((x[i]<xmin)||(x[i]>xmax)||(y[i]<ymin)||(y[i]>ymax))
		next
	    x1 = min (x1, x[i])
	    x2 = max (x2, x[i])
	    y1 = min (y1, y[i])
	    y2 = max (y2, y[i])
	    n = n + 1
	}
	if ((GT_LCLIP(gt) > 0. || GT_HCLIP(gt) > 0.) && n > 0) {
	    call malloc (buf, n, TY_REAL)
	    n = 0
	    do i = 1, npts {
		if ((x[i]<xmin)||(x[i]>xmax)||(y[i]<ymin)||(y[i]>ymax))
		    next
		Memr[buf+n] = y[i]
		n = n + 1
	    }
	    call asrtr (Memr[buf], Memr[buf], n)
	    if (GT_LCLIP(gt) > 1.)
		j = GT_LCLIP(gt) / 100. * n
	    else
		j = max (0., GT_LCLIP(gt) * n)
	    if (GT_HCLIP(gt) > 1.)
		k = GT_HCLIP(gt) / 100. * n
	    else
		k = max (0., GT_HCLIP(gt) * n)
	    k = n - 1 - k
	    if (j > k) {
		y1 = Memr[buf+j]
		y2 = Memr[buf+k]
	    }
	    call mfree (buf, TY_REAL)
	}

	if (x1 <= x2)
	    call gswind (gp, x1, x2, INDEF, INDEF)
	if (y1 <= y2)
	    call gswind (gp, INDEF, INDEF, y1, y2)
end