12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- /**
- * \brief Bridge for C programs to access solve_VPSC (which is in C++)
- *
- * Authors:
- * Tim Dwyer <[email protected]>
- *
- * Copyright (C) 2005 Authors
- *
- * This version is released under the CPL (Common Public License) with
- * the Graphviz distribution.
- * A version is also available under the LGPL as part of the Adaptagrams
- * project: https://github.com/mjwybrow/adaptagrams.
- * If you make improvements or bug fixes to this code it would be much
- * appreciated if you could also contribute those changes back to the
- * Adaptagrams repository.
- */
- #pragma once
- #include <stdbool.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- typedef struct Variable Variable;
- Variable* newVariable(int id, double desiredPos, double weight);
- void setVariableDesiredPos(Variable *, double desiredPos);
- double getVariablePos(const Variable*);
- typedef struct Constraint Constraint;
- Constraint* newConstraint(Variable* left, Variable* right, double gap);
- typedef struct VPSC VPSC;
- void deleteVPSC(VPSC*);
- void deleteConstraint(Constraint*);
- void deleteVariable(Variable*);
- Constraint** newConstraints(int m);
- void deleteConstraints(int m,Constraint**);
- void remapInConstraints(Variable *u, Variable *v, double dgap);
- void remapOutConstraints(Variable *u, Variable *v, double dgap);
- #ifndef HAVE_POINTF_S
- typedef struct pointf_s { double x, y; } pointf;
- typedef struct { pointf LL, UR; } boxf;
- #endif
- int genXConstraints(int n, boxf[], Variable** vs, Constraint*** cs,
- bool transitiveClosure);
- int genYConstraints(int n, boxf[], Variable** vs, Constraint*** cs);
- void satisfyVPSC(VPSC*);
- void solveVPSC(VPSC*);
- typedef struct IncVPSC IncVPSC;
- VPSC* newIncVPSC(int n, Variable* vs[], int m, Constraint* cs[]);
- #ifdef __cplusplus
- }
- #endif
|