Merge branch 'master' of github.com:jcupitt/libvips
This commit is contained in:
commit
38ca511694
@ -13,6 +13,7 @@
|
|||||||
- lr/tbmosaic() work for any mix of image formats / bands
|
- lr/tbmosaic() work for any mix of image formats / bands
|
||||||
- removed ancient balance stuff from im_lr/tbmosaic()
|
- removed ancient balance stuff from im_lr/tbmosaic()
|
||||||
- gtk-doc for mosaicing
|
- gtk-doc for mosaicing
|
||||||
|
- add im_fits2vips() to the operation database
|
||||||
|
|
||||||
30/11/10 started 7.24.0
|
30/11/10 started 7.24.0
|
||||||
- bump for new stable
|
- bump for new stable
|
||||||
|
@ -40,6 +40,7 @@
|
|||||||
/*
|
/*
|
||||||
*/
|
*/
|
||||||
#define DEBUG
|
#define DEBUG
|
||||||
|
#define VIPS_DEBUG
|
||||||
|
|
||||||
#ifdef HAVE_CONFIG_H
|
#ifdef HAVE_CONFIG_H
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
@ -55,6 +56,7 @@
|
|||||||
|
|
||||||
#include <vips/vips.h>
|
#include <vips/vips.h>
|
||||||
#include <vips/internal.h>
|
#include <vips/internal.h>
|
||||||
|
#include <vips/debug.h>
|
||||||
|
|
||||||
#include <fitsio.h>
|
#include <fitsio.h>
|
||||||
|
|
||||||
@ -66,14 +68,17 @@
|
|||||||
|
|
||||||
TODO
|
TODO
|
||||||
|
|
||||||
- add a tile cache, cf. tiff
|
|
||||||
|
|
||||||
- test colour read with valgrind
|
- test colour read with valgrind
|
||||||
|
|
||||||
- ask Doug for a test colour image
|
- ask Doug for a test colour image
|
||||||
|
|
||||||
|
found WFPC2u5780205r_c0fx.fits on the fits samples page,
|
||||||
|
though we don't read it correctly, argh
|
||||||
|
|
||||||
- read whole tiles, if the alignment is right
|
- read whole tiles, if the alignment is right
|
||||||
|
|
||||||
|
actually, this is hard, we'd need to flip y somehow
|
||||||
|
|
||||||
- test performance
|
- test performance
|
||||||
|
|
||||||
- remove the old scanline reader?
|
- remove the old scanline reader?
|
||||||
@ -172,7 +177,7 @@ static int fits2vips_formats[][3] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static int
|
static int
|
||||||
fits2vips_get_header( Read *read )
|
fits2vips_get_header( Read *read, IMAGE *out )
|
||||||
{
|
{
|
||||||
int status;
|
int status;
|
||||||
int bitpix;
|
int bitpix;
|
||||||
@ -191,9 +196,9 @@ fits2vips_get_header( Read *read )
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
printf( "naxis = %d\n", read->naxis );
|
VIPS_DEBUG_MSG( "naxis = %d\n", read->naxis );
|
||||||
for( i = 0; i < read->naxis; i++ )
|
for( i = 0; i < read->naxis; i++ )
|
||||||
printf( "%d) %lld\n", i, read->naxes[i] );
|
VIPS_DEBUG_MSG( "%d) %lld\n", i, read->naxes[i] );
|
||||||
#endif /*DEBUG*/
|
#endif /*DEBUG*/
|
||||||
|
|
||||||
width = 1;
|
width = 1;
|
||||||
@ -261,7 +266,7 @@ fits2vips_get_header( Read *read )
|
|||||||
else
|
else
|
||||||
type = IM_TYPE_MULTIBAND;
|
type = IM_TYPE_MULTIBAND;
|
||||||
|
|
||||||
im_initdesc( read->out,
|
im_initdesc( out,
|
||||||
width, height, bands,
|
width, height, bands,
|
||||||
im_bits_of_fmt( format ), format,
|
im_bits_of_fmt( format ), format,
|
||||||
IM_CODING_NONE, type, 1.0, 1.0, 0, 0 );
|
IM_CODING_NONE, type, 1.0, 1.0, 0, 0 );
|
||||||
@ -285,18 +290,16 @@ fits2vips_get_header( Read *read )
|
|||||||
return( -1 );
|
return( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef DEBUG
|
VIPS_DEBUG_MSG( "fits: seen:\n" );
|
||||||
printf( "fits: seen:\n" );
|
VIPS_DEBUG_MSG( " key == %s\n", key );
|
||||||
printf( " key == %s\n", key );
|
VIPS_DEBUG_MSG( " value == %s\n", value );
|
||||||
printf( " value == %s\n", value );
|
VIPS_DEBUG_MSG( " comment == %s\n", comment );
|
||||||
printf( " comment == %s\n", comment );
|
|
||||||
#endif /*DEBUG*/
|
|
||||||
|
|
||||||
im_snprintf( vipsname, 100, "fits-%s", key );
|
im_snprintf( vipsname, 100, "fits-%s", key );
|
||||||
if( im_meta_set_string( read->out, vipsname, value ) )
|
if( im_meta_set_string( out, vipsname, value ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
im_snprintf( vipsname, 100, "fits-%s-comment", key );
|
im_snprintf( vipsname, 100, "fits-%s-comment", key );
|
||||||
if( im_meta_set_string( read->out, vipsname, comment ) )
|
if( im_meta_set_string( out, vipsname, comment ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -308,18 +311,19 @@ fits2vips_header( const char *filename, IMAGE *out )
|
|||||||
{
|
{
|
||||||
Read *read;
|
Read *read;
|
||||||
|
|
||||||
#ifdef DEBUG
|
VIPS_DEBUG_MSG( "fits2vips_header: reading \"%s\"\n", filename );
|
||||||
printf( "fits2vips_header: reading \"%s\"\n", filename );
|
|
||||||
#endif /*DEBUG*/
|
|
||||||
|
|
||||||
if( !(read = read_new( filename, out )) ||
|
if( !(read = read_new( filename, out )) ||
|
||||||
fits2vips_get_header( read ) )
|
fits2vips_get_header( read, out ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Read the whole image in scanlines.
|
/* Read the whole image in scanlines.
|
||||||
|
|
||||||
|
kept for reference ... this works for colour fits images
|
||||||
|
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
fits2vips_get_data_scanlinewise( Read *read )
|
fits2vips_get_data_scanlinewise( Read *read )
|
||||||
@ -399,10 +403,9 @@ fits2vips_generate( REGION *out, void *seq, void *a, void *b )
|
|||||||
long lpixel[MAX_DIMENSIONS];
|
long lpixel[MAX_DIMENSIONS];
|
||||||
long inc[MAX_DIMENSIONS];
|
long inc[MAX_DIMENSIONS];
|
||||||
|
|
||||||
/* We read the area a scanline at a time. If the REGION we are reading
|
VIPS_DEBUG_MSG( "fits2vips_generate: "
|
||||||
* to has bpl set right we should be able to read all scanlines in one
|
"generating left = %d, top = %d, width = %d, height = %d\n",
|
||||||
* go, experiment.
|
r->left, r->top, r->width, r->height );
|
||||||
*/
|
|
||||||
|
|
||||||
for( y = r->top; y < IM_RECT_BOTTOM( r ); y ++ ) {
|
for( y = r->top; y < IM_RECT_BOTTOM( r ); y ++ ) {
|
||||||
for( z = 0; z < MAX_DIMENSIONS; z++ )
|
for( z = 0; z < MAX_DIMENSIONS; z++ )
|
||||||
@ -436,19 +439,6 @@ fits2vips_generate( REGION *out, void *seq, void *a, void *b )
|
|||||||
return( 0 );
|
return( 0 );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Read the image in chunks on demand.
|
|
||||||
*/
|
|
||||||
static int
|
|
||||||
fits2vips_get_data_lazy( Read *read )
|
|
||||||
{
|
|
||||||
if( im_demand_hint( read->out, IM_SMALLTILE, NULL ) ||
|
|
||||||
im_generate( read->out,
|
|
||||||
NULL, fits2vips_generate, NULL, read, NULL ) )
|
|
||||||
return( -1 );
|
|
||||||
|
|
||||||
return( 0 );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* im_fits2vips:
|
* im_fits2vips:
|
||||||
* @filename: file to load
|
* @filename: file to load
|
||||||
@ -456,7 +446,6 @@ fits2vips_get_data_lazy( Read *read )
|
|||||||
*
|
*
|
||||||
* Read a FITS image file into a VIPS image.
|
* Read a FITS image file into a VIPS image.
|
||||||
*
|
*
|
||||||
*
|
|
||||||
* See also: #VipsFormat.
|
* See also: #VipsFormat.
|
||||||
*
|
*
|
||||||
* Returns: 0 on success, -1 on error.
|
* Returns: 0 on success, -1 on error.
|
||||||
@ -464,17 +453,22 @@ fits2vips_get_data_lazy( Read *read )
|
|||||||
int
|
int
|
||||||
im_fits2vips( const char *filename, IMAGE *out )
|
im_fits2vips( const char *filename, IMAGE *out )
|
||||||
{
|
{
|
||||||
|
const int tile_size = 128;
|
||||||
|
|
||||||
Read *read;
|
Read *read;
|
||||||
|
IMAGE *cache;
|
||||||
|
|
||||||
#ifdef DEBUG
|
VIPS_DEBUG_MSG( "im_fits2vips: reading \"%s\"\n", filename );
|
||||||
printf( "im_fits2vips: reading \"%s\"\n", filename );
|
|
||||||
#endif /*DEBUG*/
|
|
||||||
|
|
||||||
if( !(read = read_new( filename, out )) )
|
if( !(cache = im_open_local( out, "cache", "p" )) ||
|
||||||
return( -1 );
|
!(read = read_new( filename, out )) ||
|
||||||
if( fits2vips_get_header( read ) ||
|
fits2vips_get_header( read, cache ) ||
|
||||||
fits2vips_get_data_lazy( read ) )
|
im_demand_hint( cache, IM_SMALLTILE, NULL ) ||
|
||||||
// fits2vips_get_data_scanlinewise( read ) )
|
im_generate( cache,
|
||||||
|
NULL, fits2vips_generate, NULL, read, NULL ) ||
|
||||||
|
im_tile_cache( cache, out,
|
||||||
|
tile_size, tile_size,
|
||||||
|
2 * (1 + cache->Xsize / tile_size) ) )
|
||||||
return( -1 );
|
return( -1 );
|
||||||
|
|
||||||
return( 0 );
|
return( 0 );
|
||||||
@ -486,15 +480,13 @@ isfits( const char *filename )
|
|||||||
fitsfile *fptr;
|
fitsfile *fptr;
|
||||||
int status;
|
int status;
|
||||||
|
|
||||||
#ifdef DEBUG
|
VIPS_DEBUG_MSG( "isfits: testing \"%s\"\n", filename );
|
||||||
printf( "isfits: testing \"%s\"\n", filename );
|
|
||||||
#endif /*DEBUG*/
|
|
||||||
|
|
||||||
status = 0;
|
status = 0;
|
||||||
|
|
||||||
if( fits_open_image( &fptr, filename, READONLY, &status ) ) {
|
if( fits_open_image( &fptr, filename, READONLY, &status ) ) {
|
||||||
|
VIPS_DEBUG_MSG( "isfits: error reading \"%s\"\n", filename );
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
printf( "isfits: error reading \"%s\"\n", filename );
|
|
||||||
read_error( status );
|
read_error( status );
|
||||||
#endif /*DEBUG*/
|
#endif /*DEBUG*/
|
||||||
|
|
||||||
|
@ -389,10 +389,37 @@ static im_function vips2ppm_desc = {
|
|||||||
vips2ppm_arg_types /* Arg list */
|
vips2ppm_arg_types /* Arg list */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static int
|
||||||
|
fits2vips_vec( im_object *argv )
|
||||||
|
{
|
||||||
|
char *in = argv[0];
|
||||||
|
IMAGE *out = argv[1];
|
||||||
|
|
||||||
|
if( im_fits2vips( in, out ) )
|
||||||
|
return( -1 );
|
||||||
|
|
||||||
|
return( 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
static im_arg_desc fits2vips_args[] = {
|
||||||
|
IM_INPUT_STRING( "in" ),
|
||||||
|
IM_OUTPUT_IMAGE( "out" )
|
||||||
|
};
|
||||||
|
|
||||||
|
static im_function fits2vips_desc = {
|
||||||
|
"im_fits2vips", /* Name */
|
||||||
|
"convert from fits", /* Description */
|
||||||
|
0, /* Flags */
|
||||||
|
fits2vips_vec, /* Dispatch function */
|
||||||
|
IM_NUMBER( fits2vips_args ), /* Size of arg list */
|
||||||
|
fits2vips_args /* Arg list */
|
||||||
|
};
|
||||||
|
|
||||||
/* Package up all these functions.
|
/* Package up all these functions.
|
||||||
*/
|
*/
|
||||||
static im_function *list[] = {
|
static im_function *list[] = {
|
||||||
&csv2vips_desc,
|
&csv2vips_desc,
|
||||||
|
&fits2vips_desc,
|
||||||
&jpeg2vips_desc,
|
&jpeg2vips_desc,
|
||||||
&magick2vips_desc,
|
&magick2vips_desc,
|
||||||
&png2vips_desc,
|
&png2vips_desc,
|
||||||
|
@ -157,6 +157,8 @@ int im_mat2vips( const char *filename, IMAGE *out );
|
|||||||
int im_rad2vips( const char *filename, IMAGE *out );
|
int im_rad2vips( const char *filename, IMAGE *out );
|
||||||
int im_vips2rad( IMAGE *in, const char *filename );
|
int im_vips2rad( IMAGE *in, const char *filename );
|
||||||
|
|
||||||
|
int im_fits2vips( const char *filename, IMAGE *out );
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif /*__cplusplus*/
|
#endif /*__cplusplus*/
|
||||||
|
Loading…
Reference in New Issue
Block a user