/usr/share/pyshared/pywcs/include/pipeline.h is in python-pywcs 1.12-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 | /*
Copyright (C) 2008-2012 Association of Universities for Research in Astronomy (AURA)
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:
1. Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above
copyright notice, this list of conditions and the following
disclaimer in the documentation and/or other materials provided
with the distribution.
3. The name of AURA and its representatives may not be used to
endorse or promote products derived from this software without
specific prior written permission.
THIS SOFTWARE IS PROVIDED BY AURA ``AS IS'' AND ANY EXPRESS OR IMPLIED
WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL AURA BE LIABLE FOR ANY DIRECT, INDIRECT,
INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
DAMAGE.
*/
/*
Author: Michael Droettboom
mdroe@stsci.edu
*/
#ifndef __PIPELINE_H__
#define __PIPELINE_H__
#include "sip.h"
#include "distortion.h"
#include "wcs.h"
typedef struct {
distortion_lookup_t* det2im[2];
/*@shared@*/ /*@null@*/ sip_t* sip;
distortion_lookup_t* cpdis[2];
/*@shared@*/ /*@null@*/ struct wcsprm* wcs;
struct wcserr* err;
} pipeline_t;
/**
Initialize all the values in a pipeline_t to NULL.
*/
void
pipeline_clear(
pipeline_t* pipeline);
/**
Set all the values of a pipeline_t.
*/
void
pipeline_init(
pipeline_t* pipeline,
/*@shared@*/ distortion_lookup_t** det2im /* [2] */,
/*@shared@*/ sip_t* sip,
/*@shared@*/ distortion_lookup_t** cpdis /* [2] */,
/*@shared@*/ struct wcsprm* wcs);
/**
Free all the temporary buffers of a pipeline_t. It does not free
the underlying sip_t, distortion_lookup_t or wcsprm objects.
*/
void
pipeline_free(
pipeline_t* pipeline);
/**
Perform the entire pipeline from pixel coordinates to world
coordinates, in the following order:
- Detector to image plane correction (optionally)
- SIP distortion correction (optionally)
- Paper IV distortion correction (optionally)
- wcslib WCS transformation
@param ncoord:
@param nelem:
@param pixcrd [in]: Array of pixel coordinates.
@param world [out]: Array of sky coordinates (output).
@return: A wcslib error code.
*/
int
pipeline_all_pixel2world(
pipeline_t* pipeline,
const unsigned int ncoord,
const unsigned int nelem,
const double* const pixcrd /* [ncoord][nelem] */,
double* world /* [ncoord][nelem] */);
/**
Perform just the distortion correction part of the pipeline from pixel
coordinates to focal plane coordinates.
- Detector to image plane correction (optionally)
- SIP distortion correction (optionally)
- Paper IV distortion correction (optionally)
@param ncoord:
@param nelem:
@param pixcrd [in]: Array of pixel coordinates.
@param foc [out]: Array of focal plane coordinates.
@return: A wcslib error code.
*/
int
pipeline_pix2foc(
pipeline_t* pipeline,
const unsigned int ncoord,
const unsigned int nelem,
const double* const pixcrd /* [ncoord][nelem] */,
double* foc /* [ncoord][nelem] */);
#endif
|