libSBNW
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Macros Modules Pages
Classes | Enumerations | Functions
layout.h File Reference

SBML layout interface in C. More...

#include "graphfab/core/SagittariusCore.h"
#include "graphfab/sbml/autolayoutSBML.h"
#include "graphfab/diag/error.h"
#include <stdint.h>

Go to the source code of this file.

Classes

struct  gf_network
 A reaction network. More...
 
struct  gf_node
 A species in a model. More...
 
struct  gf_reaction
 A reaction in a model. More...
 
struct  gf_curve
 A 2D cubic Bezier curve. More...
 
struct  gf_compartment
 A compartment in a model. More...
 
struct  gf_canvas
 Drawing canvas. More...
 
struct  gf_layoutInfo
 Type which holds layout info. More...
 
struct  CPoint
 A point in 2D space. More...
 
struct  gf_point
 A point in 2D space. More...
 
struct  gf_transform
 A 2D affine transform. More...
 
struct  gf_curveCP
 A curve control points. More...
 

Enumerations

enum  gf_specRole {
  GF_ROLE_SUBSTRATE, GF_ROLE_PRODUCT, GF_ROLE_SIDESUBSTRATE, GF_ROLE_SIDEPRODUCT,
  GF_ROLE_MODIFIER, GF_ROLE_ACTIVATOR, GF_ROLE_INHIBITOR
}
 Species role in a reaction. More...
 

Functions

_GraphfabExport void gf_freeLayoutInfo (gf_layoutInfo *l)
 Call to clean up an instance of gf_layoutInfo when it is no longer needed. More...
 
_GraphfabExport void gf_freeLayoutInfoHierarch (gf_layoutInfo *l)
 Call to clean up an instance of gf_layoutInfo and all contained data structures. More...
 
_GraphfabExport void gf_freeModelAndLayout (gf_SBMLModel *mod, gf_layoutInfo *l)
 Call to clean up an instance of gf_layoutInfo and gf_SBMLModel when they are no longer needed. More...
 
_GraphfabExport gf_SBMLModel gf_SBMLModel_new ()
 Create a new SBML model. More...
 
_GraphfabExport gf_SBMLModelgf_SBMLModel_newp ()
 Create a new SBML model. More...
 
_GraphfabExport gf_layoutInfo gf_layoutInfo_new (uint64_t level, uint64_t version, uint64_t width, uint64_t height)
 Create a new layout info object. More...
 
_GraphfabExport gf_layoutInfogf_layoutInfo_newp (uint64_t level, uint64_t version, uint64_t width, uint64_t height)
 Create a new layout info object. More...
 
_GraphfabExport gf_layoutInfogf_processLayout (gf_SBMLModel *lo)
 Process the layout info from a document. More...
 
_GraphfabExport gf_layoutInfogf_loadSBMLIntoLayoutEngine (const char *buf, gf_SBMLModel *r)
 [DEPRECATED] Load SBML document from memory buffer and process More...
 
_GraphfabExport void gf_setModelNamespace (gf_layoutInfo *l, unsigned long level, unsigned long version)
 Set the level and version of the SBML. More...
 
_GraphfabExport const char * gf_getDefaultCompartmentId ()
 Get the id of the default SBML compartment. More...
 
_GraphfabExport void gf_setDefaultCompartmentId (const char *id)
 Set the id of the default SBML compartment. More...
 
_GraphfabExport gf_network gf_getNetwork (gf_layoutInfo *l)
 Get the network associated with the model. More...
 
_GraphfabExport gf_networkgf_getNetworkp (gf_layoutInfo *l)
 Get the network associated with the model. More...
 
_GraphfabExport void gf_clearNetwork (gf_network *n)
 Clear the network - does not deallocate. More...
 
_GraphfabExport void gf_releaseNetwork (gf_network *n)
 Release the network. More...
 
_GraphfabExport char * gf_nw_getId (gf_network *n)
 Get the id of the network (i.e. the SBML model) More...
 
_GraphfabExport void gf_nw_setId (gf_network *n, const char *id)
 Set the id of the network (via the SBML model) More...
 
_GraphfabExport uint64_t gf_nw_getNumNodes (const gf_network *n)
 Get the number of nodes. More...
 
_GraphfabExport uint64_t gf_nw_getNumUniqueNodes (const gf_network *n)
 Get the number of unique nodes. More...
 
_GraphfabExport uint64_t gf_nw_getNumRxns (const gf_network *n)
 Get the number of reactions. More...
 
_GraphfabExport uint64_t gf_nw_getNumComps (const gf_network *n)
 Get the number of compartments. More...
 
_GraphfabExport gf_node gf_nw_getNode (gf_network *n, uint64_t i)
 Get the node at index i. More...
 
_GraphfabExport gf_node gf_nw_getUniqueNode (gf_network *n, uint64_t i)
 Get the unique node at index i. More...
 
_GraphfabExport gf_nodegf_nw_getNodep (gf_network *n, uint64_t i)
 Get the node at index i. More...
 
_GraphfabExport gf_nodegf_nw_getUniqueNodep (gf_network *n, uint64_t i)
 Get the node at index i. More...
 
_GraphfabExport gf_nodegf_nw_getNodepFromId (gf_network *nw, const char *id)
 Get the node with the given id. More...
 
_GraphfabExport gf_reaction gf_nw_getRxn (gf_network *n, uint64_t i)
 Get the node at index i. More...
 
_GraphfabExport gf_reactiongf_nw_getRxnp (gf_network *n, uint64_t i)
 Get the node at index i. More...
 
_GraphfabExport void gf_nw_removeRxn (gf_network *n, gf_reaction *r)
 Remove the given reaction. More...
 
_GraphfabExport gf_compartment gf_nw_getCompartment (gf_network *n, uint64_t i)
 Get the compartment at index i. More...
 
_GraphfabExport gf_compartmentgf_nw_getCompartmentp (gf_network *n, uint64_t i)
 Get the compartment at index i. More...
 
_GraphfabExport gf_compartmentgf_nw_findCompartmentById (gf_network *n, const char *id)
 Find a compartment by id. More...
 
_GraphfabExport void gf_nw_rebuildCurves (gf_network *n)
 Rebuild all curves in the network. More...
 
_GraphfabExport void gf_nw_recenterJunctions (gf_network *n)
 Recenter reaction junctions. More...
 
_GraphfabExport gf_compartment gf_nw_newCompartment (gf_network *nw, const char *id, const char *name)
 Add a new compartment to the network. More...
 
_GraphfabExport gf_compartmentgf_nw_newCompartmentp (gf_network *nw, const char *id, const char *name)
 Add a new compartment to the network. More...
 
_GraphfabExport gf_node gf_nw_newNode (gf_network *nw, const char *id, const char *name, gf_compartment *compartment)
 Add a new node to the network. More...
 
_GraphfabExport gf_node gf_nw_aliasOf (gf_network *nw, gf_node *n)
 Creates a new node that is the alias of a given node. More...
 
_GraphfabExport gf_nodegf_nw_newNodep (gf_network *nw, const char *id, const char *name, gf_compartment *compartment)
 Add a new node to the network. More...
 
_GraphfabExport gf_nodegf_nw_newAliasNodep (gf_network *nw, gf_node *source)
 Create and add an alias node from a given source node. More...
 
_GraphfabExport int gf_nw_removeNode (gf_network *nw, gf_node *node)
 Remove a node from the network. More...
 
_GraphfabExport int gf_nw_connectNode (gf_network *nw, gf_node *node, gf_reaction *reaction, gf_specRole role)
 Connect a node to a reaction. More...
 
_GraphfabExport int gf_nw_connectNodeRoleStr (gf_network *nw, gf_node *n, gf_reaction *r, const char *role_str)
 Connect a node to a reaction. More...
 
_GraphfabExport int gf_nw_isNodeConnected (gf_network *nw, gf_node *node, gf_reaction *reaction)
 Return whether the given node is connected to the given reaction. More...
 
_GraphfabExport int gf_nw_isLayoutSpecified (gf_network *nw)
 Did the SBML model include layout? More...
 
_GraphfabExport int gf_nw_getNumInstances (gf_network *nw, gf_node *n)
 Get the number of instances of the node. More...
 
_GraphfabExport int gf_nw_getNumAliasInstances (gf_network *nw, gf_node *n)
 Get the number of instances of the node. More...
 
_GraphfabExport gf_node gf_nw_getInstance (gf_network *nw, gf_node *n, uint64_t i)
 Get the ith instance of an aliased node. More...
 
_GraphfabExport gf_nodegf_nw_getInstancep (gf_network *nw, gf_node *n, uint64_t i)
 Get the ith instance of an aliased node. More...
 
_GraphfabExport gf_nodegf_nw_getAliasInstancep (gf_network *nw, gf_node *n, uint64_t i)
 Get the ith instance of an aliased node. More...
 
_GraphfabExport void gf_node_setCompartment (gf_node *n, gf_compartment *c)
 Add a node to a compartment. More...
 
_GraphfabExport void gf_clearNode (gf_node *n)
 Clear the node - does not deallocate. More...
 
_GraphfabExport void gf_releaseNode (const gf_node *n)
 Release the node. More...
 
_GraphfabExport int gf_node_isLocked (gf_node *n)
 Is the node locked? More...
 
_GraphfabExport void gf_node_lock (gf_node *n)
 Lock the node. More...
 
_GraphfabExport void gf_node_unlock (gf_node *n)
 Unlock the node. More...
 
_GraphfabExport int gf_node_alias (gf_node *n, gf_network *m)
 Alias the node. More...
 
_GraphfabExport int gf_node_make_alias (gf_node *n, gf_network *m)
 Create aliases of a given node. More...
 
_GraphfabExport int gf_node_isAliased (gf_node *n)
 Is the node aliased? More...
 
_GraphfabExport void gf_node_setIsAlias (gf_node *n, int isAlias)
 Set whether the node is an alias node or not. More...
 
_GraphfabExport gf_point gf_node_getCentroid (gf_node *n)
 Get the centroid of the node. More...
 
_GraphfabExport void gf_node_getCentroidXY (gf_node *n, double *x, double *y)
 Get the centroid of the node. More...
 
_GraphfabExport void gf_node_setCentroid (gf_node *n, gf_point p)
 Set the centroid of the node. More...
 
_GraphfabExport double gf_node_getWidth (gf_node *n)
 Get the width of the node. More...
 
_GraphfabExport void gf_node_setWidth (gf_node *n, double width)
 Set the width of the node. More...
 
_GraphfabExport double gf_node_getHeight (gf_node *n)
 Get the height of the node. More...
 
_GraphfabExport void gf_node_setHeight (gf_node *n, double height)
 Set the height of the node. More...
 
_GraphfabExport char * gf_node_getID (gf_node *n)
 Get the id, user frees memory. More...
 
_GraphfabExport void gf_node_setID (gf_node *n, const char *id)
 Get the id, user frees memory. More...
 
_GraphfabExport const char * gf_node_getName (gf_node *n)
 Get the name, client must free memory. More...
 
_GraphfabExport void gf_node_setName (gf_node *n, const char *name)
 Set the name of a node. More...
 
_GraphfabExport int gf_node_getConnectedReactions (gf_node *n, gf_network *m, unsigned int *num, gf_reaction **rxns)
 Get a list of all reactions connected to the node. More...
 
_GraphfabExport int gf_node_getAttachedCurves (gf_node *n, gf_network *m, unsigned int *num, gf_curve **curves)
 Get a list of all curves connected to the node. More...
 
_GraphfabExport int gf_node_isIdentical (gf_node *u, gf_node *v)
 Tests whether two nodes are identical. More...
 
_GraphfabExport int gf_nw_nodeHasCompartment (gf_network *nw, gf_node *x)
 Return true if the node has a compartment assigned. More...
 
_GraphfabExport gf_compartmentgf_nw_nodeGetCompartment (gf_network *nw, gf_node *x)
 Get the compartment which contains node x. More...
 
_GraphfabExport void gf_releaseRxn (const gf_reaction *r)
 Release the reaction. More...
 
_GraphfabExport gf_reaction gf_nw_newReaction (gf_network *nw, const char *id, const char *name)
 Add a new reaction to the network. More...
 
_GraphfabExport gf_reactiongf_nw_newReactionp (gf_network *nw, const char *id, const char *name)
 Add a new reaction to the network. More...
 
_GraphfabExport char * gf_reaction_getID (gf_reaction *r)
 Get the id, user frees memory. More...
 
_GraphfabExport gf_point gf_reaction_getCentroid (gf_reaction *r)
 Get the centroid of the reaction. More...
 
_GraphfabExport void gf_reaction_setCentroid (gf_reaction *r, gf_point p)
 Set the centroid of the reaction. More...
 
_GraphfabExport uint64_t gf_reaction_getNumSpec (const gf_reaction *r)
 Get the number of species in the reaction. More...
 
_GraphfabExport int gf_reaction_hasSpec (const gf_reaction *r, const gf_node *n)
 Return true if the reaction has the given species. More...
 
_GraphfabExport gf_specRole gf_reaction_getSpecRole (const gf_reaction *r, uint64_t i)
 Get the role for spec i. More...
 
_GraphfabExport const char * gf_roleToStr (gf_specRole role)
 Convert role to string. More...
 
_GraphfabExport gf_specRole gf_strToRole (const char *str)
 Convert string to role. More...
 
_GraphfabExport uint64_t gf_reaction_specGeti (const gf_reaction *r, uint64_t i)
 Get the global index of a reactant/product/participant given its local index in a reaction. More...
 
_GraphfabExport uint64_t gf_reaction_getNumCurves (const gf_reaction *r)
 Get the number of curves in the reaction. More...
 
_GraphfabExport gf_curve gf_reaction_getCurve (const gf_reaction *r, uint64_t i)
 Get the curve i. More...
 
_GraphfabExport gf_curvegf_reaction_getCurvep (const gf_reaction *r, uint64_t i)
 Get the curve i. More...
 
_GraphfabExport void gf_reaction_recenter (gf_reaction *r)
 Recenter reaction centroid. More...
 
_GraphfabExport void gf_reaction_recalcCurveCPs (gf_reaction *r)
 Recalculate the curve CPs, don't recenter. More...
 
_GraphfabExport void gf_releaseCurve (const gf_curve *c)
 Release the curve. More...
 
_GraphfabExport gf_specRole gf_curve_getRole (gf_curve *c)
 Get the id, user frees memory. More...
 
_GraphfabExport gf_curveCP gf_getCurveCPs (const gf_curve *c)
 Get the CPs for the curve. More...
 
_GraphfabExport int gf_curve_hasArrowhead (const gf_curve *c)
 Returns true if the given curve should be drawn with an arrowhead. More...
 
_GraphfabExport int gf_curve_getArrowheadVerts (const gf_curve *c, unsigned int *n, gf_point **v)
 Get the vertices for the curve's arrowhead. More...
 
_GraphfabExport void gf_releaseCompartment (const gf_compartment *c)
 Release a compartment object. More...
 
_GraphfabExport char * gf_compartment_getID (gf_compartment *c)
 Get the id, user frees memory. More...
 
_GraphfabExport gf_point gf_compartment_getMinCorner (gf_compartment *c)
 Get the "upper left" corner. More...
 
_GraphfabExport void gf_compartment_setMinCorner (gf_compartment *c, gf_point p)
 Set the "upper left" corner. More...
 
_GraphfabExport gf_point gf_compartment_getMaxCorner (gf_compartment *c)
 Get the "lower right" corner. More...
 
_GraphfabExport void gf_compartment_setMaxCorner (gf_compartment *c, gf_point p)
 Set the "lower right" corner. More...
 
_GraphfabExport double gf_compartment_getWidth (gf_compartment *c)
 Get the width of the compartment. More...
 
_GraphfabExport double gf_compartment_getHeight (gf_compartment *c)
 Get the height of the compartment. More...
 
_GraphfabExport uint64_t gf_compartment_getNumElt (gf_compartment *c)
 Get the number of species in the compartment. More...
 
_GraphfabExport int gf_compartment_addNode (gf_compartment *c, gf_node *n)
 Add a node to the compartment. More...
 
_GraphfabExport int gf_compartment_removeNode (gf_compartment *c, gf_node *n)
 Remove a node from the compartment. More...
 
_GraphfabExport int gf_compartment_containsNode (gf_compartment *c, gf_node *n)
 Return whether the compartment contains this node. More...
 
_GraphfabExport int gf_compartment_containsReaction (gf_compartment *c, gf_reaction *r)
 Return whether the compartment contains this node. More...
 
_GraphfabExport void gf_fit_to_window (gf_layoutInfo *l, double left, double top, double right, double bottom)
 Fit to the specified window. More...
 
_GraphfabExport gf_transformgf_tf_fitToWindow (gf_layoutInfo *l, double left, double top, double right, double bottom)
 Fit to the specified window (do not apply transform) More...
 
_GraphfabExport void gf_moveNetworkToFirstQuad (gf_layoutInfo *l, double x_disp, double y_disp)
 Move the entire network to the first quadrant. More...
 
_GraphfabExport CPoint gf_tf_apply_to_point (gf_transform *tf, CPoint p)
 Apply transform to point. More...
 
_GraphfabExport gf_point gf_tf_getScale (gf_transform *tf)
 Get the scale of the transform. More...
 
_GraphfabExport gf_point gf_tf_getDisplacement (gf_transform *tf)
 Get the displacement of the transform. More...
 
_GraphfabExport gf_point gf_tf_getPostDisplacement (gf_transform *tf)
 Get the displacement component of the transform. More...
 
_GraphfabExport void gf_dump_transform (gf_transform *tf)
 Dump transform. More...
 
_GraphfabExport void gf_release_transform (gf_transform *tf)
 Release transform. More...
 
_GraphfabExport gf_canvas gf_getCanvas (gf_layoutInfo *l)
 Get the canvas associated with the model. More...
 
_GraphfabExport gf_canvasgf_getCanvasp (gf_layoutInfo *l)
 Get the canvas associated with the model. More...
 
_GraphfabExport void gf_clearCanvas (gf_canvas *c)
 Get the canvas associated with the model. More...
 
_GraphfabExport void gf_releaseCanvas (gf_canvas *c)
 Release the canvas. More...
 
_GraphfabExport unsigned int gf_canvGetWidth (gf_canvas *c)
 Get the width of the canvas. More...
 
_GraphfabExport unsigned int gf_canvGetHeight (gf_canvas *c)
 Get the height of the canvas. More...
 
_GraphfabExport void gf_canvSetWidth (gf_canvas *c, unsigned long width)
 Set the width of the canvas. More...
 
_GraphfabExport void gf_canvSetHeight (gf_canvas *c, unsigned long height)
 Set the height of the canvas. More...
 
_GraphfabExport void gf_getNodeCentroid (gf_layoutInfo *l, const char *id, CPoint *p)
 Get the centroid of a node. More...
 
_GraphfabExport int gf_lockNodeId (gf_layoutInfo *l, const char *id)
 Lock a node by id. More...
 
_GraphfabExport int gf_unlockNodeId (gf_layoutInfo *l, const char *id)
 Unlock a node by id. More...
 
_GraphfabExport int gf_aliasNodeId (gf_layoutInfo *l, const char *id)
 Create node aliases. More...
 
_GraphfabExport void gf_aliasNodebyDegree (gf_layoutInfo *l, const int minDegree)
 Create node aliases by node degree. More...
 
_GraphfabExport void gf_randomizeLayout (gf_layoutInfo *m)
 Randomize node positions. More...
 
_GraphfabExport void gf_randomizeLayout2 (gf_network *n, gf_canvas *c)
 Randomize node positions for a given network & canvas. More...
 
_GraphfabExport void gf_randomizeLayout_fromExtents (gf_network *n, double left, double top, double right, double bottom)
 Randomize node positions for a given network & extents. More...
 
_GraphfabExport int gf_writeSBMLwithLayout (const char *filename, gf_SBMLModel *m, gf_layoutInfo *l)
 Write an SBML file, including layout. More...
 
_GraphfabExport int gf_writeSBML (const char *filename, gf_SBMLModel *m)
 Write an SBML file (does not include layout. More...
 
_GraphfabExport const char * gf_getSBMLwithLayoutStr (gf_SBMLModel *m, gf_layoutInfo *l)
 String version of writeSBMLwithLayout. More...
 
_GraphfabExport const char * gf_getCurrentLibraryVersion (void)
 Returns the current version of the library. More...
 
_GraphfabExport void gf_free (void *x)
 Frees the memory block at x. More...
 
_GraphfabExport gf_point gf_computeCubicBezierPoint (gf_curveCP *c, Real t)
 Compute a point on the parametric curve. More...
 
_GraphfabExport gf_pointgf_computeCubicBezierLineIntersec (gf_curveCP *c, gf_point *line_start, gf_point *line_end)
 Compute the intersection between a cubic Bezier and a line. More...
 
_GraphfabExport int gf_arrowheadStyleGetNumVerts (int style)
 Get the number of vertices in the arrowhead polygon. More...
 
_GraphfabExport gf_point gf_arrowheadStyleGetVert (int style, int n)
 Get the nth vertex of the arrow polygon. More...
 
_GraphfabExport int gf_arrowheadStyleIsFilled (int style)
 Is the given style filled? More...
 
_GraphfabExport unsigned long gf_arrowheadNumStyles ()
 Get the number of arrowhead styles. More...
 
_GraphfabExport void gf_arrowheadSetStyle (gf_specRole role, int style)
 Set the arrowhead style for a specific role type. More...
 
_GraphfabExport int gf_arrowheadGetStyle (gf_specRole role)
 Get the style for the role type. More...
 

Detailed Description

SBML layout interface in C.

Function Documentation

_GraphfabExport int gf_aliasNodeId ( gf_layoutInfo l,
const char *  id 
)

Create node aliases.

Parameters
[in]lThe layout info; contains the network which holds the list of nodes to be searched
[in]idThe node id; used to find the correct node in the layout
[out]0if success
[out]1if failure
Deprecated:
_GraphfabExport int gf_lockNodeId ( gf_layoutInfo l,
const char *  id 
)

Lock a node by id.

Parameters
[in]lThe layout info; contains the network that holds the list of nodes to be searched
[in]idThe node id; used to find the correct node in the layout
[out]0if success
[out]1if failure
Deprecated:
_GraphfabExport int gf_unlockNodeId ( gf_layoutInfo l,
const char *  id 
)

Unlock a node by id.

Parameters
[in]lThe layout info; contains the network with the nodes to be searched
[in]idThe node id; used to find the correct node in the layout
[out]0if success
[out]1if failure
Deprecated: