jfaustin's picture
secretion-scores (#4)
a3f3d91 verified
#ifndef FREESASA_INTERNAL_H
#define FREESASA_INTERNAL_H
#include <stdio.h>
#include "freesasa.h"
#include "coord.h"
//! The name of the library, to be used in error messages
extern const char *freesasa_name;
//! The name of the package, to be used in regular output (includes version)
extern const char *freesasa_string;
//! A ::freesasa_nodearea with `name == NULL` and all values 0
extern const freesasa_nodearea freesasa_nodearea_null;
//! Shortcut for memory error generation
#define mem_fail() freesasa_mem_fail(__FILE__,__LINE__)
//! Shortcut for error message with position information, should be used by default
#define fail_msg(...) freesasa_fail_wloc(__FILE__,__LINE__, __VA_ARGS__)
/**
Calculate SASA using S&R algorithm.
@param sasa The results are written to this array, the user has to
make sure it is large enough.
@param c Coordinates of the object to calculate SASA for.
@param radii Array of radii for each sphere.
@param param Parameters specifying resolution, probe radius and
number of threads. If NULL :.freesasa_default_parameters is used.
@return ::FREESASA_SUCCESS on success, ::FREESASA_WARN if multiple
threads are requested when compiled in single-threaded mode (with
error message). ::FREESASA_FAIL if memory allocation failure.
*/
int
freesasa_shrake_rupley(double *sasa,
const coord_t *c,
const double *radii,
const freesasa_parameters *param);
/**
Calculate SASA using L&R algorithm.
Solvent accessible surface area for each atom is written to the
array 'sasa'. The user is responsible for making sure this has the
right size. The argument grid sets the distance between grid
points in Å. Returns FREESASA_SUCCESS on success, FREESASA_WARN if
multiple threads are requested when compiled in single-threaded
mode (with error message).
@param sasa The results are written to this array, the user has to
make sure it is large enough.
@param c Coordinates of the object to calculate SASA for.
@param radii Array of radii for each sphere.
@param param Parameters specifying resolution, probe radius and
number of threads. If NULL :.freesasa_default_parameters is used.
@return ::FREESASA_SUCCESS on success, ::FREESASA_WARN if
multiple threads are requested when compiled in single-threaded
mode (with error message). ::FREESASA_FAIL if memory allocation
failure.
*/
int freesasa_lee_richards(double* sasa,
const coord_t *c,
const double *radii,
const freesasa_parameters *param);
/**
Calculate SASA based on a coordinate object, radii and parameters
Wrapper for freesasa_lee_richards() and freesasa_shrake_rupley()
that creates a result object.
Return value is dynamically allocated, should be freed with
freesasa_result_free().
@param c Coordinates
@param radii Atomi radii
@param parameters Parameters
@return Result of calculation, NULL if something went wrong.
*/
freesasa_result*
freesasa_calc(const coord_t *c,
const double *radii,
const freesasa_parameters *parameters);
int
freesasa_write_log(FILE *log,
freesasa_node *root);
/**
Print RSA-file
@param output Output-file.
@param root A tree with stored results.
@param options Bitfield with option ::FREESASA_OUTPUT_SKIP_REL to specify
if REL column should be populated or not. If the classifier has no
reference values, it will be left empty either way.
@return ::FREESASA_SUCCESS on success, ::FREESASA_FAIL if problems
writing to file.
*/
int
freesasa_write_rsa(FILE *output,
freesasa_node *root,
int options);
/**
Export to JSON
Not thread-safe.
@param output Output-file.
@param root A tree with stored results.
@param parameters Parameters used in the calculation (NULL means
defaults are assumed).
@param options Bitfield with options ::FREESASA_OUTPUT_STRUCTURE,
::FREESASA_OUTPUT_CHAIN and ::FREESASA_OUTPUT_RESIDUE, that specify
depth of the tree to output. If `options == 0` all levels are
written. The options ::FREESASA_OUTPUT_SKIP_REL specifies
if REL column should be populated or not. If the classifier has no
reference values, it will be left empty either way.
@return ::FREESASA_SUCCESS on success, ::FREESASA_FAIL if problems
writing to file.
*/
int
freesasa_write_json(FILE *ouput,
freesasa_node *root,
int options);
/**
Export to XML
@param output Output-file.
@param root A tree with stored results.
@param parameters Parameters used in the calculation (NULL means
defaults are assumed).
@param options Bitfield with options ::FREESASA_OUTPUT_STRUCTURE,
::FREESASA_OUTPUT_CHAIN and ::FREESASA_OUTPUT_RESIDUE, that specify
depth of the tree to output. If `options == 0` all levels
written. The options ::FREESASA_OUTPUT_SKIP_REL specifies
if REL column should be populated or not. If the classifier has no
reference values, it will be left empty either way.
@return ::FREESASA_SUCCESS on success, ::FREESASA_FAIL if problems
writing to file.
*/
int
freesasa_write_xml(FILE *ouput,
freesasa_node *root,
int options);
/**
Write SASA values and atomic radii to new PDB-file.
Takes PDB information from the provided structure and writes a new
PDB-file to output, where the B-factors have been replaced with
the atom's SASA values in the results, and the occupancy
factors with the radii.
Will only work if the structure was initialized from a PDB-file, i.e.
using freesasa_structure_from_pdb() or freesasa_structure_array().
@param output Output-file
@param structure A ::freesasa_node of type ::FREESASA_NODE_STRUCTURE
@return ::FREESASA_SUCCESS if file written successfully.
::FREESASA_FAIL if there is no previous PDB input to base output
on or if there were problems writing to the file.
*/
int
freesasa_write_pdb(FILE *output,
freesasa_node *structure);
/**
Write per-residue-type output
*/
int
freesasa_write_res(FILE *log,
freesasa_node *root);
/**
Write SASA per residue in sequence output
*/
int
freesasa_write_seq(FILE *log,
freesasa_node *root);
/**
Write standard log message.
*/
int
freesasa_write_log(FILE *log,
freesasa_node *root);
/**
Clone results object
*/
freesasa_result *
freesasa_result_clone(const freesasa_result *result);
/**
Clone selection object
*/
freesasa_selection *
freesasa_selection_clone(const freesasa_selection *selection);
/**
Get coordinates.
@param structure A structure.
@return The coordinates of the structure as a ::coord_t struct.
*/
const coord_t *
freesasa_structure_xyz(const freesasa_structure *structure);
/**
The class of an atom, in the classifier used to initialize the structure.
@param structure A structure.
@param i Atom index.
@return The class.
*/
freesasa_atom_class
freesasa_structure_atom_class(const freesasa_structure *structure,
int i);
/**
The PDB line used to generate the atom.
@param structure A structure.
@param i Atom index.
@return The line, NULL if structure wasn't generated from a PDB file.
*/
const char *
freesasa_structure_atom_pdb_line(const freesasa_structure *structure,
int i);
const freesasa_nodearea *
freesasa_structure_residue_reference(const freesasa_structure *structure,
int r_i);
/**
Get the index of a chain.
@param structure A structure.
@param chain The chain label.
@return The index of `chain` in the structure. ::FREESASA_FAIL
if `chain` not found.
*/
int
freesasa_structure_chain_index(const freesasa_structure *structure,
char chain);
/**
Extract area to provided ::freesasa_nodearea object
Main-chain / side-chain atoms are defined by
::freesasa_backbone_classifier.
@param area Area will be stored here
@param structure Structure to use for classification
@param result The areas to use
@param atom_index Index of atom in question
@return ::FREESASA_SUCCESS. ::FREESASA_FAIL if memory
allocation for name fails.
*/
int
freesasa_atom_nodearea(freesasa_nodearea *area,
const freesasa_structure *structure,
const freesasa_result *result,
int atom_index);
/**
Adds all members of term to corresponding members of sum
@param sum Object to add to
@param term Object to add
*/
void
freesasa_add_nodearea(freesasa_nodearea *sum,
const freesasa_nodearea *term);
/**
Compute nodearea for a range of atoms
*/
void
freesasa_range_nodearea(freesasa_nodearea *area,
const freesasa_structure *structure,
const freesasa_result *result,
int first_atom,
int last_atom);
/**
Calculate relative SASA values for a residue
If the array `ref_values` does not have an entry that has the same
`name` as `abs`, `rel->name` will be `NULL`.
@param rel Store results here, will have same name as `abs`
@param abs Absolute SASA for residue
@param reference Reference SASA for the residue
*/
void
freesasa_residue_rel_nodearea(freesasa_nodearea *rel,
const freesasa_nodearea *abs,
const freesasa_nodearea *reference);
/**
Is an atom a backbone atom
@param atom_name Name of atom
@return 1 if the atom_name equals CA, N, O or C after whitespace
is trimmed, 0 else. (i.e. does not check if it is an actual atom)
*/
int
freesasa_atom_is_backbone(const char *atom_name);
/**
Holds range in a file, to be initalized with ftell() and used
with fseek().
*/
struct file_range {
long begin; //!< Position of beginning of range
long end; //!< Position of end of range
};
/**
For convenience, get a file range that covers a whole file.
@param file The file to study
@return the ::file_range.
*/
struct file_range
freesasa_whole_file(FILE* file);
/**
Algorithm name
@param algorithm The algorithm
@return Name
*/
const char*
freesasa_alg_name(freesasa_algorithm algorithm);
/**
Print failure message using format string and arguments.
Prefer using the macro fail_msg().
@param format Format string
@return ::FREESASA_FAIL
*/
int
freesasa_fail(const char *format,...);
/**
Print warning message using format string and arguments.
@param format Format string
@return ::FREESASA_WARN
*/
int
freesasa_warn(const char *format,...);
/**
Print warning message using function, file and line-number.
Usually used via the macro mem_fail().
@param func Name of the function that failed
@param file The file where the function is.
@param line Line number for the error.
@return ::FREESASA_FAIL
*/
int
freesasa_mem_fail(const char* file,
int line);
/**
Returns string explaining return values of pthread_create() and
pthread_join().
@param error_code The error code
@return A string describing the error code.
*/
const char*
freesasa_thread_error(int error_code);
/**
Prints fail message with function name, file name, and line number.
Mainly intended to be used by the macros fail_msg() and mem_fail().
@param file The file name
@param line The line number
@param msg The error message
@return ::FREESASA_FAIL
*/
int
freesasa_fail_wloc(const char* file,
int line,
const char *format,
...);
#endif /* FREESASA_INTERNAL_H */