This commit is contained in:
John Cupitt 2009-03-27 17:23:11 +00:00
parent 47dec2610f
commit 1160f6a4b7
14 changed files with 343 additions and 166 deletions

View File

@ -1,5 +1,6 @@
25/3/09 started 7.18.0 25/3/09 started 7.18.0
- revised version numbers - revised version numbers
- updated vipsmanual
6/3/09 started 7.17.3 6/3/09 started 7.17.3
- revised nohalo - revised nohalo

12
TODO
View File

@ -1,17 +1,21 @@
- im_rank.3 has a note about a black border, argh
any other references to this?
- VipsFormat.3 man page should list all formats, since eg. radiance does not - VipsFormat.3 man page should list all formats, since eg. radiance does not
have a separate im_rad2vips page have a separate im_rad2vips page
also matlab read also matlab read
- wrap im_gauss_mask_line or whatever it's called in C++/Python?
- need man pages for im_affinei, im_affinei_all - need man pages for im_affinei, im_affinei_all
page for VipsInterpolate.3? along the lines of VipsFormat page for VipsInterpolate.3? along the lines of VipsFormat
- read through docs for 7.18 stuff - Mention vips --list-classes or whatever in VipsFormat man page
:set spell also in VipsInterpolate
- update function list in refs
WONTFIX for 7.18 WONTFIX for 7.18
================ ================

View File

@ -2,7 +2,7 @@
\mylabel{sec:appl} \mylabel{sec:appl}
This chapter explains how to call VIPS functions from C programs. It does not This chapter explains how to call VIPS functions from C programs. It does not
explain how to write new image processing operations (See \pref{sec:oper}), explain how to write new image processing operations (see \pref{sec:oper}),
only how to call the ones that VIPS provides. If you want to call VIPS only how to call the ones that VIPS provides. If you want to call VIPS
functions from C++ programs, you can either use the interface described here functions from C++ programs, you can either use the interface described here
or you can try out the much nicer C++ interface described in \pref{sec:cpp}. or you can try out the much nicer C++ interface described in \pref{sec:cpp}.
@ -26,7 +26,7 @@ example% man im_extract
\noindent \noindent
to get an explanation of the \verb+im_extract()+ function. to get an explanation of the \verb+im_extract()+ function.
All the comand-line vips operations will print help text too. For example: All the command-line VIPS operations will print help text too. For example:
\begin{verbatim} \begin{verbatim}
example% vips im_extract example% vips im_extract

View File

@ -2,10 +2,10 @@
\label{sec:format} \label{sec:format}
VIPS has a simple system for adding support for new image file formats. VIPS has a simple system for adding support for new image file formats.
You can ask VIPS to find a format to load a file with You can ask VIPS to find a format to load a file with or to select a image
or to select a image file writer based on a filename. Convenience functions file writer based on a filename. Convenience functions copy a file to an
copy a file to an \verb+IMAGE+, or an \verb+IMAGE+ to a file. New formats may \verb+IMAGE+, or an \verb+IMAGE+ to a file. New formats may be added to
be added to VIPS by simply defining a new subclass of \verb+VipsFormat+. VIPS by simply defining a new subclass of \verb+VipsFormat+.
This is a parallel API to \verb+im_open()+, see \pref{sec:open}. The This is a parallel API to \verb+im_open()+, see \pref{sec:open}. The
format system is useful for images which are large or slow to open, format system is useful for images which are large or slow to open,
@ -42,16 +42,6 @@ version is one indicating that the file can be opened lazily
\end{itemize} \end{itemize}
A switch to the \verb+vips+ command-line program is handy for listing the
supported formats. Try:
\begin{verbatim}
vips --list classes
\end{verbatim}
\noindent
And look for subclasses of \verb+VipsFormat+.
\subsection{The format class} \subsection{The format class}
The interface to the format system is defined by the abstract base class The interface to the format system is defined by the abstract base class

View File

@ -1,5 +1,8 @@
\section{Function dispatch and plug-ins} \section{Function dispatch and plug-ins}
(This chapter is on the verge of being deprecated. We have started building a
replacement based on \verb+GObject+, see \pref{sec:object}.)
As image processing libraries increase in size it becomes progressively more As image processing libraries increase in size it becomes progressively more
difficult to build applications which present the operations the library difficult to build applications which present the operations the library
offers to the user. Every time a new operation is added, every user interface offers to the user. Every time a new operation is added, every user interface
@ -13,7 +16,7 @@ simply interrogate the database and present what they find to the user.
The operation database is extensible. You can define new operations, and even The operation database is extensible. You can define new operations, and even
new types, and add them to VIPS. These new operations will then automatically new types, and add them to VIPS. These new operations will then automatically
appear in all VIPS user interfaces with no extra programming effort. Plugins appear in all VIPS user interfaces with no extra programming effort. Plugins
can extend the database at runtime: when VIPS starts, it loads all the plugin can extend the database at runtime: when VIPS starts, it loads all the plugins
in the VIPS library area. in the VIPS library area.
\subsection{Simple plugin example} \subsection{Simple plugin example}
@ -84,50 +87,66 @@ macros available are listed in table~\ref{tab:type}.
Macro & Meaning & Macro & Meaning &
\texttt{im\_object} has type \\ \texttt{im\_object} has type \\
\hline \hline
\texttt{IM\_INPUT\_IMAGEVEC} & Vector of input images & \texttt{IM\_INPUT\_INT} & Input int &
\texttt{IMAGE **} \\ \texttt{int *} \\
\texttt{IM\_INPUT\_IMAGE} & Input image & \texttt{IM\_INPUT\_INTVEC} & Input vector of int &
\texttt{IMAGE *} \\ \texttt{im\_intvec\_object *} \\
\texttt{IM\_OUTPUT\_IMAGE} & Output image & \texttt{IM\_INPUT\_IMASK} & Input int array &
\texttt{IMAGE *} \\ \texttt{im\_mask\_object *} \\
\texttt{IM\_RW\_IMAGE} & Read-write image &
\texttt{IMAGE *} \\ \texttt{IM\_OUTPUT\_INT} & Output int &
\texttt{int *} \\
\texttt{IM\_INPUT\_INTVEC} & Output vector of int &
\texttt{im\_intvec\_object *} \\
\texttt{IM\_OUTPUT\_IMASK} & Output int array to file &
\texttt{im\_mask\_object *} \\
\texttt{IM\_INPUT\_DOUBLE} & Input double & \texttt{IM\_INPUT\_DOUBLE} & Input double &
\texttt{double *} \\ \texttt{double *} \\
\texttt{IM\_INPUT\_DOUBLEVEC} & Input vector of double & \texttt{IM\_INPUT\_DOUBLEVEC} & Input vector of double &
\texttt{im\_realvec\_object *} \\ \texttt{im\_realvec\_object *} \\
\texttt{IM\_INPUT\_INTVEC} & Input vector of int &
\texttt{im\_intvec\_object *} \\
\texttt{IM\_OUTPUT\_DOUBLE} & Output double &
\texttt{double *} \\
\texttt{IM\_INPUT\_INT} & Input int &
\texttt{int *} \\
\texttt{IM\_OUTPUT\_INT} & Output int &
\texttt{int *} \\
\texttt{IM\_INPUT\_STRING} & Input string &
\texttt{char *} \\
\texttt{IM\_OUTPUT\_STRING} & Output string &
\texttt{char *} \\
\texttt{IM\_INPUT\_DISPLAY} & Input display &
\texttt{im\_col\_display *} \\
\texttt{IM\_OUTPUT\_DISPLAY} & Output display &
\texttt{im\_col\_display *} \\
\texttt{IM\_OUTPUT\_COMPLEX} & Output complex &
\texttt{double *} \\
\texttt{IM\_INPUT\_DMASK} & Input double array & \texttt{IM\_INPUT\_DMASK} & Input double array &
\texttt{im\_mask\_object *} \\ \texttt{im\_mask\_object *} \\
\texttt{IM\_OUTPUT\_DOUBLE} & Output double &
\texttt{double *} \\
\texttt{IM\_OUTPUT\_DOUBLEVEC} & Output vector of double &
\texttt{im\_realvec\_object *} \\
\texttt{IM\_OUTPUT\_DMASK} & Output double array to file & \texttt{IM\_OUTPUT\_DMASK} & Output double array to file &
\texttt{im\_mask\_object *} \\ \texttt{im\_mask\_object *} \\
\texttt{IM\_OUTPUT\_DMASK\_STATS}& Output double array to screen & \texttt{IM\_OUTPUT\_DMASK\_STATS}& Output double array to screen &
\\ \\
\texttt{IM\_INPUT\_IMASK} & Input int array &
\texttt{im\_mask\_object *} \\ \texttt{IM\_OUTPUT\_COMPLEX} & Output complex &
\texttt{IM\_OUTPUT\_IMASK} & Output int array to file & \texttt{double *} \\
\texttt{im\_mask\_object *} \\
\texttt{IM\_INPUT\_STRING} & Input string &
\texttt{char *} \\
\texttt{IM\_OUTPUT\_STRING} & Output string &
\texttt{char *} \\
\texttt{IM\_INPUT\_IMAGE} & Input image &
\texttt{IMAGE *} \\
\texttt{IM\_INPUT\_IMAGEVEC} & Vector of input images &
\texttt{IMAGE **} \\
\texttt{IM\_OUTPUT\_IMAGE} & Output image &
\texttt{IMAGE *} \\
\texttt{IM\_RW\_IMAGE} & Read-write image &
\texttt{IMAGE *} \\
\texttt{IM\_INPUT\_DISPLAY} & Input display &
\texttt{im\_col\_display *} \\
\texttt{IM\_OUTPUT\_DISPLAY} & Output display &
\texttt{im\_col\_display *} \\
\texttt{IM\_INPUT\_GVALUE} & Input GValue & \texttt{IM\_INPUT\_GVALUE} & Input GValue &
\texttt{GValue *} \\ \texttt{GValue *} \\
\texttt{IM\_OUTPUT\_GVALUE} & Output GValue & \texttt{IM\_OUTPUT\_GVALUE} & Output GValue &
\texttt{GValue *} \\ \texttt{GValue *} \\
\texttt{IM\_INPUT\_INTERPOLATE} & Input VipsInterpolate &
\texttt{VipsInterpolate *} \\
\hline \hline
\end{tabular} \end{tabular}
\end{center} \end{center}

View File

@ -14,7 +14,7 @@ typedef void (*VipsInterpolateMethod)( VipsInterpolate *,
\end{verbatim} \end{verbatim}
\noindent \noindent
Given the set of input pixels \verb+in+, it has to calculate a value for the given the set of input pixels \verb+in+, it has to calculate a value for the
fractional position $(x, y)$ and write this value to the memory pointed to by fractional position $(x, y)$ and write this value to the memory pointed to by
\verb+out+. \verb+out+.
@ -43,16 +43,6 @@ NULL and just set the int value \verb+window_size+.
\end{itemize} \end{itemize}
A switch to the \verb+vips+ command-line program is handy for listing the
supported interpolators. Try:
\begin{verbatim}
vips --list classes
\end{verbatim}
\noindent
And look for subclasses of \verb+VipsInterpolate+.
\subsection{A sample interpolator} \subsection{A sample interpolator}
As an example, \fref{fg:newinterpolator} shows how to register a new As an example, \fref{fg:newinterpolator} shows how to register a new
@ -61,20 +51,27 @@ interpolator in a plugin.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
// This interpolator adds no new members. // This interpolator adds no new members.
typedef VipsInterpolate VipsInterpolateMyinterpolator; typedef VipsInterpolate Myinterpolator;
typedef VipsInterpolateClass VipsInterpolateMyinterpolator; typedef VipsInterpolateClass MyinterpolatorClass;
G_DEFINE_TYPE( Myinterpolator, myinterpolator, VIPS_TYPE_INTERPOLATE );
static void static void
vips_interpolate_myinterpolator_interpolate( VipsInterpolate *interpolate, myinterpolator_interpolate( VipsInterpolate *interpolate,
PEL *out, REGION *in, double x, double y ) PEL *out, REGION *in, double x, double y )
{ {
VipsInterpolateBilinearClass *class = MyinterpolatorClass *class =
VIPS_INTERPOLATE_BILINEAR_GET_CLASS( interpolate ); MYINTERPOLATOR_GET_CLASS( interpolate );
/* Nearest-neighbor.
*/
memcpy( out,
IM_REGION_ADDR( in, floor( x ), floor( y ) ),
IM_IMAGE_SIZEOF_PEL( in->im ) );
}
static void static void
vips_interpolate_myinterpolator_class_init( myinterpolator_class_init( MyinterpolatorClass *class )
VipsInterpolateMyinterpolatorClass *class )
{ {
VipsObjectClass *object_class = (VipsObjectClass *) class; VipsObjectClass *object_class = (VipsObjectClass *) class;
VipsInterpolateClass *interpolate_class = (VipsInterpolateClass *) class; VipsInterpolateClass *interpolate_class = (VipsInterpolateClass *) class;
@ -82,29 +79,56 @@ vips_interpolate_myinterpolator_class_init(
object_class->nickname = "myinterpolator"; object_class->nickname = "myinterpolator";
object_class->description = _( "My interpolator" ); object_class->description = _( "My interpolator" );
interpolate_class->interpolate = my_interpolate; interpolate_class->interpolate = myinterpolator_interpolate;
} }
static void static void
vips_interpolate_myinterpolate_init( VipsInterpolateMyinterpolate *object ) myinterpolate_init( Myinterpolate *object )
{ {
} }
G_DEFINE_TYPE( VipsInterpolateMyinterpolator, vips_interpolate_myinterpolator,
VIPS_TYPE_INTERPOLATE );
char * char *
g_module_check_init( GModule *self ) g_module_check_init( GModule *self )
{ {
// register the type // register the type
vips_format_myformat_get_type(); myinterpolator_get_type();
} }
\end{verbatim} \end{verbatim}
\caption{Registering an interpolator in a plugin} \caption{Registering an interpolator in a plugin}
\label{fg:newinterpolator} \label{fg:newinterpolator}
\end{fig2} \end{fig2}
\subsection{Passing an interpolator to a VIPS operation}
\subsection{Writing a VIPS operation that takes an interpolator as an argument} \subsection{Writing a VIPS operation that takes an interpolator as an argument}
Operations just take a \verb+VipsInterpolate+ as an argument, for example:
\begin{verbatim}
int im_affinei_all( IMAGE *in, IMAGE *out,
VipsInterpolate *interpolate,
double a, double b, double c, double d,
double dx, double dy );
\end{verbatim}
To use the interpolator, use \verb+vips_interpolate()+:
\begin{verbatim}
void vips_interpolate( VipsInterpolate *interpolate,
PEL *out, REGION *in, double x, double y );
\end{verbatim}
\noindent
This looks up the interpolate method for the object and calls it for you.
You can save the cost of the lookup in an inner loop with
\verb+vips_interpolate_get_method()+:
\begin{verbatim}
VipsInterpolateMethod
vips_interpolate_get_method(
VipsInterpolate *interpolate );
\end{verbatim}
\subsection{Passing an interpolator to a VIPS operation}
You can build an instance of a \verb+VipsInterpolator+ with
the \verb+vips_object_*()+ family of functions, see \pref{sec:object}.

View File

@ -1,13 +1,12 @@
\section{Core C API} \section{Core C API}
VIPS is VIPS is built on top of several other libraries, two of which, glib and
built on top of several other libraries, two of which, glib and gobject, are gobject, are exposed at various points in the C API.
exposed at various points in the C API.
You can read up on glib at the GTK+ website: You can read up on glib at the GTK+ website:
\begin{verbatim} \begin{verbatim}
http://www.gtk.org/api http://www.gtk.org
\end{verbatim} \end{verbatim}
There's also an excellent book by Matthias Warkus, \emph{The Official There's also an excellent book by Matthias Warkus, \emph{The Official
@ -168,6 +167,15 @@ Descriptors are created with \verb+im_open()+. You can also read images with
the format system: see \pref{sec:format}. The two APIs are complimentary, the format system: see \pref{sec:format}. The two APIs are complimentary,
though \verb+im_open()+ is more useful. though \verb+im_open()+ is more useful.
At the command-line, try:
\begin{verbatim}
$ vips --list classes
\end{verbatim}
/noindent
to see a list of all the supported file formats.
\verb+im_open()+ takes a file name and a string representing the mode with \verb+im_open()+ takes a file name and a string representing the mode with
which the descriptor is to be opened: which the descriptor is to be opened:
@ -187,10 +195,8 @@ different byte ordering, \verb+im_open()+ will automatically convert it to
native VIPS format. If the underlying file does not support random access native VIPS format. If the underlying file does not support random access
(JPEG, for example), the entire file will be converted in memory. (JPEG, for example), the entire file will be converted in memory.
VIPS can read images in TIFF, JPEG, PPM/\-PGM/\-PBM, PNG and VIPS VIPS can read images in many file formats. You can control the details of
format, all in both big- and little-endian varieties. You can control the the conversion with extra characters embedded in the filename. For example:
details of the conversion with extra characters embedded in the filename. For
example:
\begin{verbatim} \begin{verbatim}
fred = im_open( "fred.tif:2", fred = im_open( "fred.tif:2",
@ -200,25 +206,15 @@ fred = im_open( "fred.tif:2",
\noindent \noindent
will read page 2 of a multi-page TIFF. See the man pages for details. will read page 2 of a multi-page TIFF. See the man pages for details.
If VIPS has been built with libMagick, it can also read any of the 80 or so
libMagick-supported image file formats.
\item[\texttt{"w"}] \item[\texttt{"w"}]
An \verb+IMAGE+ descriptor is created which, when written to, will write An \verb+IMAGE+ descriptor is created which, when written to, will write
pixels to disc in the specified file. pixels to disc in the specified file. Any existing file of that name is
deleted.
VIPS looks at the filename suffix to determine the save format. If there VIPS looks at the filename suffix to determine the save format. If there
is no suffix, or the filename ends in \verb+".v"+, the image is written is no suffix, or the filename ends in \verb+".v"+, the image is written
in VIPS native format. in VIPS native format.
If the filename ends in \verb+".tif"+ or \verb+".tiff"+, the image
is written with \verb+im_vips2tiff()+. If the filename ends in
\verb+".jpg"+, \verb+".jpeg"+ or \verb+".jpe"+, the image is written with
\verb+im_vips2jpg()+. If the filename ends with \verb+".pbm"+, \verb+".pgm"+
or \verb+".ppm"+, the image is written using \verb+im_vips2ppm()+.
If the filename ends with \verb+".png"+, the image is written using
\verb+im_vips2png()+. Case is not considered when testing the suffix.
If you want to control the details of the conversion to the disc format (such If you want to control the details of the conversion to the disc format (such
as setting the Q factor for a JPEG, for example), you embed extra control as setting the Q factor for a JPEG, for example), you embed extra control
characters in the filename. For example: characters in the filename. For example:
@ -283,12 +279,6 @@ void error_exit( const char *format,
There are other functions for handling errors: see the man page for There are other functions for handling errors: see the man page for
\verb+im_error()+. \verb+im_error()+.
If the file name given to \verb+im_open()+ ends with \verb+".v"+, VIPS
looks in the same directory as the image for a file with the same name
but with the extension \verb+".desc"+. If present, this file is read in
and a pointer to the data put in the \verb+Hist+ field of the descriptor. See
the notes on \verb+im_updatehist()+ in \pref{sec:examples}.
Descriptors are closed with \verb+im_close()+. It has type: Descriptors are closed with \verb+im_close()+. It has type:
\begin{verbatim} \begin{verbatim}
@ -296,10 +286,6 @@ int im_close( IMAGE *im )
\end{verbatim} \end{verbatim}
\verb+im_close()+ returns 0 on success and non-zero on error. \verb+im_close()+ returns 0 on success and non-zero on error.
If the descriptor represents a disc file which
has been written to and whose name ends in \verb+".v"+, VIPS writes the
\verb+Hist+ field of the image descriptor to a file in the same directory
whose name ends in \verb+".desc"+.
\subsection{Examples} \subsection{Examples}
\label{sec:examples} \label{sec:examples}
@ -394,10 +380,10 @@ main( int argc, char **argv )
\label{sec:meta} \label{sec:meta}
VIPS lets you attach arbitrary metadata to an IMAGE. For example, ICC VIPS lets you attach arbitrary metadata to an IMAGE. For example, ICC
profiles, EXIF tags, whatever you like. VIPS will efficiently propogate profiles, EXIF tags, image history, whatever you like. VIPS will efficiently
metadata as images are processed (usually just by copying pointers) and will propagate metadata as images are processed (usually just by copying
automatically save and load metadata from VIPS files (see pointers) and will automatically save and load metadata from VIPS files
\pref{sec:header}). (see \pref{sec:header}).
A piece of metadata is a value and an identifying name. A set of A piece of metadata is a value and an identifying name. A set of
convenience functions let you set and get int, double, string and blob. For convenience functions let you set and get int, double, string and blob. For
@ -432,9 +418,8 @@ if( im_meta_get_int( im, "poop", &i ) )
And get the value 42 back. And get the value 42 back.
You can use \verb+im_meta_set()+ and \verb+im_meta_get()+ to attach arbitrary You can use \verb+im_meta_set()+ and \verb+im_meta_get()+ to attach arbitrary
\verb+GValue+ to images. \verb+GValue+ to images. See the man page for \verb+im_meta_set()+ for
See the man page for \verb+im_meta_set()+ for full full details.
details.
You can test for a field being present with \verb+im_meta_get_type()+ (you'll You can test for a field being present with \verb+im_meta_get_type()+ (you'll
get \verb+G_TYPE_INT+ back for \verb+"poop"+, for example, or 0 if it is not get \verb+G_TYPE_INT+ back for \verb+"poop"+, for example, or 0 if it is not
@ -476,7 +461,7 @@ const char *
VIPS lets you attach callbacks to image descriptors. These are functions VIPS lets you attach callbacks to image descriptors. These are functions
you provide which VIPS will call when certain events occur. See you provide which VIPS will call when certain events occur. See
\pref{sec:callback} for a full list. \pref{sec:callback} for more detail.
Eval callbacks are called repeatedly during evaluation and can be used by Eval callbacks are called repeatedly during evaluation and can be used by
user-interface programs to give feedback about the progress of evaluation. user-interface programs to give feedback about the progress of evaluation.
@ -649,7 +634,7 @@ for more help.
All VIPS operations return 0 on success and non-zero on error, setting All VIPS operations return 0 on success and non-zero on error, setting
\verb+im_error()+. As a consequence, when a VIPS function fails, you do not \verb+im_error()+. As a consequence, when a VIPS function fails, you do not
need to generate an error message --- you can simply propogate the error back need to generate an error message --- you can simply propagate the error back
up to your caller. If however you detect some error yourself (for example, up to your caller. If however you detect some error yourself (for example,
the bad parameter in the example above), you must call \verb+im_error()+ the bad parameter in the example above), you must call \verb+im_error()+
to let your caller know what the problem was. to let your caller know what the problem was.
@ -657,7 +642,7 @@ to let your caller know what the problem was.
VIPS provides two more functions for error message handling: \verb+im_warn()+ VIPS provides two more functions for error message handling: \verb+im_warn()+
and \verb+im_diag()+. These are intended to be used for less serious and \verb+im_diag()+. These are intended to be used for less serious
messages, as their names suggest. Currently, they simply format and print messages, as their names suggest. Currently, they simply format and print
their arguments to \verb+stderr+, optionally supressed by the setting of an their arguments to \verb+stderr+, optionally suppressed by the setting of an
environment variable. Future releases of VIPS may allow more sophisticated environment variable. Future releases of VIPS may allow more sophisticated
trapping of these functions to allow their text to be easily presented to trapping of these functions to allow their text to be easily presented to
the user by VIPS applications. See the manual pages. the user by VIPS applications. See the manual pages.
@ -700,8 +685,9 @@ images larger than the amount of RAM you have on your machine.
As an added bonus, if you have more than one CPU in your computer, the work As an added bonus, if you have more than one CPU in your computer, the work
will be automatically spread across the processors for you. You can control will be automatically spread across the processors for you. You can control
this parallelisation with the \verb+IM_CONCURRENCY+ environment variable and this parallelization with the \verb+IM_CONCURRENCY+ environment variable,
with \verb+im_concurrency_set()+. See the man page for \verb+im_generate()+. \verb+im_concurrency_set()+, and with the \verb+--vips-concurrency+
command-line switch. See the man page for \verb+im_generate()+.
\subsubsection{How it works} \subsubsection{How it works}
@ -796,7 +782,8 @@ and throw it all away, keeping only the average value. The subsequent call to
When designing a program, it is sensible to pay attention to these When designing a program, it is sensible to pay attention to these
issues. It might be faster, in some cases, to output to a file before issues. It might be faster, in some cases, to output to a file before
calling \verb+im_avg()+, find the average of the disc file, and then run calling \verb+im_avg()+, find the average of the disc file, and then run
\verb+im_moreconst()+ from that. \verb+im_moreconst()+ from that. There's also \verb+im_cache()+ which can keep
recent parts of a very large image.
\subsubsection{Blocking computation} \subsubsection{Blocking computation}
\label{sec:block} \label{sec:block}
@ -814,7 +801,7 @@ from being followed.
\label{sec:limit} \label{sec:limit}
Not all VIPS operations are partial-aware. These non-partial operations Not all VIPS operations are partial-aware. These non-partial operations
use a pre-VIPS7.0 I/O scheme in which the whole of the input image has to use a pre-VIPS 7.0 I/O scheme in which the whole of the input image has to
be present at the same time. In some cases, this is because partial I/O be present at the same time. In some cases, this is because partial I/O
simply makes no sense --- for example, a Fourier Transform can produce no simply makes no sense --- for example, a Fourier Transform can produce no
output until it has seen all of the input. \verb+im_fwfft()+ is therefore output until it has seen all of the input. \verb+im_fwfft()+ is therefore

134
doc/src/object.tex Normal file
View File

@ -0,0 +1,134 @@
\section{The VIPS base class: \texttt{VipsObject}}
\label{sec:object}
VIPS is in the process of moving to an object system based on \verb+GObject+.
You can read about the \verb+GObjec+ library at the GTK+ website:
\begin{verbatim}
http://www.gtk.org
\end{verbatim}
We've implemented two new subsystems (\verb+VipsFormat+ and
\verb+VipsInterpolate+) on top of \verb+VipsObject+ but not yet moved the core
VIPS types over. As a result, \verb+VipsObject+ is still developing and is
likely to change in the next release.
This section quickly summarises enough of the \verb+VipsObject+ system to let
you use the two derived APIs but that's all. Full documentation will come when
this system stabilises.
\subsection{Properties}
Like the rest of VIPS, \verb+VipsObject+ is a functional type. You can set
properties during object construction, but not after that point. You may read
properties at any time after construction, but not before.
To enforce these rules, VIPS extends the standard \verb+GObject+ property
system and adds a new phase to object creation. An object has the following
stages in its life:
\subsubsection{Lookup}
\verb+vips_type_find()+ is a convenience function that looks up a type by its
nickname relative to a base class. For example:
\begin{verbatim}
GType type =
vips_type_find( "VipsInterpolate", "bilinear" );
\end{verbatim}
\noindent
finds a subclass of \verb+VipsInterpolate+ nicknamed `bilinear'. You can look
up types by their full name of course, but these can be rather unwieldy
(\verb+VipsInterpolateBilinear+ in this case, for example).
\subsubsection{Create}
Build an instance with \verb+g_object_new()+. For example:
\begin{verbatim}
VipsObject *object =
g_object_new( type,
"sharpness", 12.0,
NULL );
\end{verbatim}
You can set any of the object's properties in the constructor. You can
continue to set, but not read, any other properties, for example:
\begin{verbatim}
g_object_set( object,
"sharpness", 12.0,
NULL );
\end{verbatim}
You can loop over an object's required and optional parameters with
\verb+vips_argument_map()+.
\subsubsection{Build}
Once all of the required any any of the optional object parameters have been
set, call \verb+vips_object_build()+:
\begin{verbatim}
int vips_object_build( VipsObject *object );
\end{verbatim}
This function checks that all the parameters have been set correctly and
starts the object working. It returns non-zero on error, setting
\verb+im_error_string()+.
\subsubsection{Use}
The object is now fully working. You can read results from it, or pass it on
other objects. When you're finished with it, drop your reference to end its
life.
\begin{verbatim}
g_object_unref( object );
\end{verbatim}
\subsection{Convenience functions}
Two functions simplify building and printing objects.
\verb+vips_object_new_from_string()+ makes a new object which is a subclass of
a named base class.
\begin{verbatim}
VipsObject *
vips_object_new_from_string(
const char *basename, const char *p );
\end{verbatim}
This is the function used by \verb+IM_INPUT_INTERPOLATE()+, for example, to
parse command-line arguments. The syntax is:
\begin{verbatim}
nickname [ ( required-arg1,
...
required-argn,
optional-arg-name = value,
...
optional-argm-name = value ) ]
\end{verbatim}
So values for all the required arguments, in the correct order, then name =
value for all the optional arguments you want to set. Parameters may be
enclosed in round or curly braces.
\verb+vips_object_to_string()+ is the exact opposite: it generates the
construct string for any constructed
\verb+VipsObject+.
\verb+vips_object_new()+ wraps up the business of creating and checking an
object. It makes the object, uses the supplied function to attach any
arguments, then builds the object and returns NULL on failure or the new
object on success.
A switch to the \verb+vips+ command-line program is handy for listing subtypes
of \verb+VipsObject+. Try:
\begin{verbatim}
$ vips --list classes
\end{verbatim}

View File

@ -37,8 +37,8 @@ Provided you use PIO and as long as the underlying OS supports large files
(that is, files larger than 2GB), VIPS operations can work on files larger (that is, files larger than 2GB), VIPS operations can work on files larger
than can be addressed with 32 bits on a plain 32-bit machine. VIPS operations than can be addressed with 32 bits on a plain 32-bit machine. VIPS operations
only see 32 bit addresses; the VIPS I/O system transparently maps these to only see 32 bit addresses; the VIPS I/O system transparently maps these to
64 bit operations for I/O. Large file support is included on most unixes after 64 bit operations for I/O. Large file support is included on most machines
about 1998. after about 1998.
\item[Abstraction] \item[Abstraction]
VIPS operations see only arrays of numbers in native format. Details of VIPS operations see only arrays of numbers in native format. Details of
@ -98,12 +98,3 @@ and \verb+im_wrapmany()+ operations. These take a simple buffer-processing
operation supplied by you and wrap it up as a full-blown PIO operation. operation supplied by you and wrap it up as a full-blown PIO operation.
See~\pref{sec:wrapone}. See~\pref{sec:wrapone}.
\subsection{What's new in this version}
The VIPS API is mostly unaltered since 7.3, so there are not many major
changes. I've just reworked the text, reformatted, fixed a few typos,
and changed the dates.
VIPS has acquired some crud over the years. We are planning to clean all
this stuff up at some stage (and break backwards-compatibility). Maybe for
VIPS 8 :-(

View File

@ -21,7 +21,7 @@ in the manual pages.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
john% vips --list arithmetic $ vips --list arithmetic
im_abs - absolute value im_abs - absolute value
im_acostra - acos of image (result in degrees) im_acostra - acos of image (result in degrees)
im_add - add two images im_add - add two images
@ -63,7 +63,7 @@ im_powtra - pel^x ofbuildimage
im_powtra_vec - pel^[x,y,z] of image im_powtra_vec - pel^[x,y,z] of image
im_remainder - remainder after integer division im_remainder - remainder after integer division
im_remainderconst - remainder after integer division by a constant im_remainderconst - remainder after integer division by a constant
im_remainderconst_vec - remainder after int division by vector of constants im_remainderconst_vec - remainder after integer division by a vector of constants
im_rint - round to nearest integal value im_rint - round to nearest integal value
im_sign - unit vector in direction of value im_sign - unit vector in direction of value
im_sintra - sin of image (angles in degrees) im_sintra - sin of image (angles in degrees)
@ -92,7 +92,7 @@ condition is true (or false) for a whole image.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
john% vips --list relational $ vips --list relational
im_blend - use cond image to blend between images in1 and in2 im_blend - use cond image to blend between images in1 and in2
im_equal - two images equal in value im_equal - two images equal in value
im_equal_vec - image equals doublevec im_equal_vec - image equals doublevec
@ -129,7 +129,7 @@ the relational and morphological functions. You can use
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
john% vips --list boolean $ vips --list boolean
im_andimage - bitwise and of two images im_andimage - bitwise and of two images
im_andimageconst - bitwise and of an image with a constant im_andimageconst - bitwise and of an image with a constant
im_andimage_vec - bitwise and of an image with a vector constant im_andimage_vec - bitwise and of an image with a vector constant
@ -228,7 +228,7 @@ or \verb+disp+ colour space.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list colour $ vips --list colour
im_LCh2Lab - convert LCh to Lab im_LCh2Lab - convert LCh to Lab
im_LCh2UCS - convert LCh to UCS im_LCh2UCS - convert LCh to UCS
im_Lab2LCh - convert Lab to LCh im_Lab2LCh - convert Lab to LCh
@ -262,6 +262,7 @@ im_dE_fromXYZ - calculate delta-E for two XYZ images
im_dE_fromdisp - calculate delta-E for two displayable images im_dE_fromdisp - calculate delta-E for two displayable images
im_disp2Lab - convert displayable to Lab im_disp2Lab - convert displayable to Lab
im_disp2XYZ - convert displayable to XYZ im_disp2XYZ - convert displayable to XYZ
im_float2rad - convert float to Radiance packed
im_icc_ac2rc - convert LAB from AC to RC using an ICC profile im_icc_ac2rc - convert LAB from AC to RC using an ICC profile
im_icc_export - convert a float LAB to an 8-bit device image with an ICC profile im_icc_export - convert a float LAB to an 8-bit device image with an ICC profile
im_icc_export_depth - convert a float LAB to device space with an ICC profile im_icc_export_depth - convert a float LAB to device space with an ICC profile
@ -270,6 +271,7 @@ im_icc_import_embedded - convert a device image to float LAB using the embedded
im_icc_present - test for presence of ICC library im_icc_present - test for presence of ICC library
im_icc_transform - convert between two device images with a pair of ICC profiles im_icc_transform - convert between two device images with a pair of ICC profiles
im_lab_morph - morph colourspace of a LAB image im_lab_morph - morph colourspace of a LAB image
im_rad2float - convert Radiance packed to float
im_sRGB2XYZ - convert sRGB to XYZ im_sRGB2XYZ - convert sRGB to XYZ
\end{verbatim} \end{verbatim}
\caption{Colour functions} \caption{Colour functions}
@ -293,7 +295,7 @@ join of many images at the same time. See the manual pages.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list conversion $ vips --list conversion
im_bandjoin - bandwise join of two images im_bandjoin - bandwise join of two images
im_bernd - extract from pyramid as jpeg im_bernd - extract from pyramid as jpeg
im_black - generate black image im_black - generate black image
@ -421,7 +423,7 @@ sections.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list matrix $ vips --list matrix
im_matcat - append matrix in2 to the end of matrix in1 im_matcat - append matrix in2 to the end of matrix in1
im_matinv - invert matrix im_matinv - invert matrix
im_matmul - multiply matrix in1 by matrix in2 im_matmul - multiply matrix in1 by matrix in2
@ -467,7 +469,7 @@ expect.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list convolution $ vips --list convolution
im_addgnoise - add gaussian noise with mean 0 and std. dev. sigma im_addgnoise - add gaussian noise with mean 0 and std. dev. sigma
im_compass - convolve with 8-way rotating integer mask im_compass - convolve with 8-way rotating integer mask
im_contrast_surface - find high-contrast points in an image im_contrast_surface - find high-contrast points in an image
@ -488,6 +490,7 @@ im_fastcor - fast correlate in2 within in1
im_fastcor_raw - fast correlate in2 within in1, no border im_fastcor_raw - fast correlate in2 within in1, no border
im_gauss_dmask - generate gaussian DOUBLEMASK im_gauss_dmask - generate gaussian DOUBLEMASK
im_gauss_imask - generate gaussian INTMASK im_gauss_imask - generate gaussian INTMASK
im_gauss_imask_sep - generate separable gaussian INTMASK
im_gaussnoise - generate image of gaussian noise with specified statistics im_gaussnoise - generate image of gaussian noise with specified statistics
im_grad_x - horizontal difference image im_grad_x - horizontal difference image
im_grad_y - vertical difference image im_grad_y - vertical difference image
@ -532,7 +535,7 @@ not.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list inplace $ vips --list inplace
im_circle - plot circle on image im_circle - plot circle on image
im_flood_blob_copy - flood while pixel == start pixel im_flood_blob_copy - flood while pixel == start pixel
im_insertplace - draw image sub inside image main at position (x,y) im_insertplace - draw image sub inside image main at position (x,y)
@ -571,7 +574,7 @@ for an image.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list freq_filt $ vips --list freq_filt
im_create_fmask - create frequency domain filter mask im_create_fmask - create frequency domain filter mask
im_disp_ps - make displayable power spectrum im_disp_ps - make displayable power spectrum
im_flt_image_freq - frequency domain filter image im_flt_image_freq - frequency domain filter image
@ -611,7 +614,7 @@ functions are useful combinations of these basic operations.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list histograms_lut $ vips --list histograms_lut
im_gammacorrect - gamma-correct image im_gammacorrect - gamma-correct image
im_heq - histogram-equalise image im_heq - histogram-equalise image
im_hist - find and graph histogram of image im_hist - find and graph histogram of image
@ -692,7 +695,7 @@ union operations.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list morphology $ vips --list morphology
im_cntlines - count horizontal or vertical lines im_cntlines - count horizontal or vertical lines
im_dilate - dilate image with mask, adding a black border im_dilate - dilate image with mask, adding a black border
im_dilate_raw - dilate image with mask im_dilate_raw - dilate image with mask
@ -744,8 +747,7 @@ images.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list mosaicing $ vips --list mosaicing
im_affine - affine transform
im_align_bands - align the bands of an image im_align_bands - align the bands of an image
im_correl - search area around sec for match for area around ref im_correl - search area around sec for match for area around ref
im__find_lroverlap - search for left-right overlap of ref and sec im__find_lroverlap - search for left-right overlap of ref and sec
@ -760,8 +762,6 @@ im_match_linear - resample ref so that tie-points match
im_match_linear_search - search sec, then resample so that tie-points match im_match_linear_search - search sec, then resample so that tie-points match
im_maxpos_subpel - subpixel position of maximum of (phase correlation) image im_maxpos_subpel - subpixel position of maximum of (phase correlation) image
im_remosaic - automatically rebuild mosaic with new files im_remosaic - automatically rebuild mosaic with new files
im_similarity_area - output area xywh of similarity transformation
im_similarity - similarity transformation
im_tbmerge - top-bottom merge of in1 and in2 im_tbmerge - top-bottom merge of in1 and in2
im_tbmerge1 - first-order top-bottom merge of in1 and in2 im_tbmerge1 - first-order top-bottom merge of in1 and in2
im_tbmosaic - top-bottom mosaic of in1 and in2 im_tbmosaic - top-bottom mosaic of in1 and in2
@ -780,7 +780,7 @@ They are useful for removing noise from images.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list cimg $ vips --list cimg
im_greyc - noise-removing filter im_greyc - noise-removing filter
im_greyc_mask - noise-removing filter, with a mask im_greyc_mask - noise-removing filter, with a mask
\end{verbatim} \end{verbatim}
@ -799,7 +799,7 @@ The \verb+im_benchmark*()+ operations are for testing the VIPS SMP system.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list other $ vips --list other
im_benchmark - do something complicated for testing im_benchmark - do something complicated for testing
im_benchmark2 - do something complicated for testing im_benchmark2 - do something complicated for testing
im_benchmarkn - do something complicated for testing im_benchmarkn - do something complicated for testing
@ -823,7 +823,7 @@ These functions are related to the image IO system.
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list iofuncs $ vips --list iofuncs
im_binfile - open a headerless binary file im_binfile - open a headerless binary file
im_cache - cache results of an operation im_cache - cache results of an operation
im_guess_prefix - guess install area im_guess_prefix - guess install area
@ -848,7 +848,7 @@ These functions convert to and from various image formats. See
\begin{fig2} \begin{fig2}
\begin{verbatim} \begin{verbatim}
example% vips --list format $ vips --list format
im_csv2vips - read a file in csv format im_csv2vips - read a file in csv format
im_jpeg2vips - convert from jpeg im_jpeg2vips - convert from jpeg
im_magick2vips - load file with libMagick im_magick2vips - load file with libMagick
@ -867,3 +867,22 @@ im_vips2tiff - convert VIPS image to TIFF file
\caption{Format functions} \caption{Format functions}
\label{fg:format} \label{fg:format}
\end{fig2} \end{fig2}
\subsection{Resample functions}
See \fref{fg:resample}.
These functions resample images with various interpolators.
\begin{fig2}
\begin{verbatim}
$ vips --list resample
im_affine - affine transform
im_affinei - affine transform
im_affinei_all - affine transform of whole image
im_similarity_area - output area xywh of similarity transformation
im_similarity - similarity transformation
\end{verbatim}
\caption{Resample functions}
\label{fg:resample}
\end{fig2}

View File

@ -43,10 +43,10 @@ user-interfaces, or you can run it from the UNIX command line with the
\vips{} program. For example: \vips{} program. For example:
\begin{verbatim} \begin{verbatim}
john% vips im_vips2tiff cam.v t1.tif none $ vips im_vips2tiff cam.v t1.tif none
john% vips im_tiff2vips t1.tif t2.v.v 0 $ vips im_tiff2vips t1.tif t2.v.v 0
john% vips im_equal cam.v t2.v t3.v $ vips im_equal cam.v t2.v t3.v
john% vips im_min t3.v $ vips im_min t3.v
255 255
\end{verbatim} \end{verbatim}
@ -54,10 +54,10 @@ VIPS may have been set up at your site with a set of links which call the
vips program for you. You may also be able to type: vips program for you. You may also be able to type:
\begin{verbatim} \begin{verbatim}
john% im_vips2tiff cam.v t1.tif none $ im_vips2tiff cam.v t1.tif none
john% im_tiff2vips t1.tif t2.v.v 0 $ im_tiff2vips t1.tif t2.v.v 0
john% im_equal cam.v t2.v t3.v $ im_equal cam.v t2.v t3.v
john% im_min t3.v $ im_min t3.v
\end{verbatim} \end{verbatim}
There are a few VIPS programs which you cannot run with \vips{}, either There are a few VIPS programs which you cannot run with \vips{}, either

View File

@ -3,7 +3,7 @@
The \verb+VDisplay+ class is an abstraction over the VIPS \verb+im_col_display+ The \verb+VDisplay+ class is an abstraction over the VIPS \verb+im_col_display+
type which gives convenient and safe representation of VIPS display profiles. type which gives convenient and safe representation of VIPS display profiles.
VIPS display profiles are now obsolete. You're better off using the VIPS display profiles are now mostly obsolete. You're better off using the
ICC colour management \verb+VImage+ member functions \verb+ICC_export()+ and ICC colour management \verb+VImage+ member functions \verb+ICC_export()+ and
\verb+ICC_import()+. \verb+ICC_import()+.

View File

@ -27,7 +27,7 @@
\begin{center} \begin{center}
\huge \huge
VIPS Manual\\ VIPS Manual\\
\large Version 7.14\\ \large Version 7.18\\
\vspace{0.5in} \vspace{0.5in}
\large \large
John Cupitt, John Cupitt,
@ -72,6 +72,7 @@ This manual formatted \today
\input{applintro} \input{applintro}
\input{iosys} \input{iosys}
\input{func} \input{func}
\input{object}
\input{format} \input{format}
\input{interpolate} \input{interpolate}

View File

@ -2,10 +2,10 @@
The \verb+VMask+ class is an abstraction over the VIPS \verb+DOUBLEMASK+ and The \verb+VMask+ class is an abstraction over the VIPS \verb+DOUBLEMASK+ and
\verb+INTMASK+ types which gives convenient and safe representation of \verb+INTMASK+ types which gives convenient and safe representation of
matricies. matrices.
\verb+VMask+ has two sub-classes, \verb+VIMask+ and \verb+VDMask+. These \verb+VMask+ has two sub-classes, \verb+VIMask+ and \verb+VDMask+. These
represent matricies of integers and doubles respectively. represent matrices of integers and doubles respectively.
\subsection{Constructors} \subsection{Constructors}
@ -109,6 +109,13 @@ for( int x = 0; x < fred.xsize(); x++ )
\noindent \noindent
will set the leading diagonal to 12. will set the leading diagonal to 12.
These don't work well in Python, so there's an extra member, \verb+get()+,
which will get an element by $x,y$ position.
\begin{verbatim}
x = mat.get (2, 4)
\end{verbatim}
See the member functions below for other operations on \verb+VMask+. See the member functions below for other operations on \verb+VMask+.
\subsection{\texttt{VIMask} operations} \subsection{\texttt{VIMask} operations}