-
Notifications
You must be signed in to change notification settings - Fork 0
Mirror repository for Keenan Crane's trivial connection https://www.cs.cmu.edu/~kmcrane/Projects/TrivialConnections/
License
n-taka/tcods
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
=============================================================================== TCODS v0.1 Keenan Crane September 18, 2010 =============================================================================== -------------- 0. CONTENTS -------------- 0. CONTENTS 1. ABOUT 2. DEPENDENCIES 3. BUILDING 4. TESTING 5. USAGE 6. FILE FORMATS 7. SOURCE CODE 8. LICENSE ----------- 1. ABOUT ----------- This archive contains a C++ implementation of an algorithm for computing direction fields with prescribed singularities on polygon meshes. It is based on the paper K. Crane, M. Desbrun, and P. Schršder, "Trivial Connections on Discrete Surfaces," Computer Graphics Forum (SGP) 2010. The command-line utility included with this implementation takes a manifold, triangulated mesh (with or without boundary) plus a specification of singular points as input, and produces the same mesh plus a single tangent vector in each face. The direction field is guaranteed to have exactly the requested singularities so long as the sum of the requested singular indices adds up to the Euler characteristic X = |V|-|E|+|F| of the input surface. PLEASE NOTE that this is research code and has not been tested extensively (in fact, not at all!) on other systems. Luckily, it was written by a friendly researcher who is happy to help you out via email in your times of trouble: [email protected] ------------------ 2. DEPENDENCIES ------------------ TCODS depends on Tim Davis' SuiteSparseQR sparse QR factorization library: http://www.cise.ufl.edu/research/sparse/SPQR/ which in turn depends on SuiteSparse and METIS: http://www.cise.ufl.edu/research/sparse/SuiteSparse/ http://glaros.dtc.umn.edu/gkhome/views/metis as well as some (hopefully optimized!) BLAS/LAPACK implementation. On UNIX-like systems you will probably end up needing the libraries bamd.a libcamd.a libcolamd.a libccolamd.a libcholmod.a libspqr.a from SuiteSparse and libmetis.a from METIS. If you want to avoid compiling all of SuiteSparse, you can simply type "make" in each of the appropriate Lib directories (e.g., AMD/Lib) after setting up UFConfig and copying the resulting library (.a) files to /usr/local/bin or some other appropriate place. Further instructions on building SuiteSparse and its dependencies can be found on the SuiteSparse home page. On Mac OS X, the easiest way to link to an efficient BLAS implementation is by adding the framework -framework Accelerate On other platforms, Kazushige Goto's GotoBLAS library is a popular choice: http://www.tacc.utexas.edu/tacc-projects/gotoblas2/ -------------- 3. BUILDING -------------- On UNIX-like systems, you should simply need to type make at the command line in the root install directory. This should build the command-line utility "tcods." On Windows it may be simplest to install Cygwin: http://www.cygwin.com/ which includes an implementation of the GNUMake system which can be used to execute the Makefiles for TCODS, SuiteSparse, and METIS. If you need to build code that does not depend on Cygwin DLLs, MINGW is an option: http://www.mingw.org/ Finally, it should not be too difficult to setup a VisualStudio project for TCODS itself, though I have no experience building SuiteSparse, METIS, or BLAS with VisualStudio. ------------- 4. TESTING ------------- To test that TCODS built correctly, type ./tcods test/problem.txt diff test/solution.eobj test/reference_solution.eobj at the command line. Depending on output formatting and the libraries used for BLAS, linear solver, etc., your result may not match the reference solution exactly, but it should be pretty close. For additional testing on Mac OS X, you can compare with the results computed by Comb: http://www.cs.caltech.edu/~keenan/project_tcods.html ----------- 5. USAGE ----------- The tcods executable takes as input a file describing a "problem," i.e., an input mesh file and a specification of singularities. Input is given by a standard ASCII text file containing lines of the following format in any order: in [path to input mesh file] out [path to output data] vertex [0-based vertex ID] [target holonomy] ... generator [0-based generator ID] [target holonomy] ... angle [initial field angle] Terms in square brackets [] are specified by the user; vertex and generator IDs must be within a valid range (namely, nonnegative integers less than the total number of vertices and non-contractible cycles in the mesh, respectively). An example input file can be found in test/problem.txt Once a problem file has been created, the problem can be solved by typing ./tcods problem.txt at the command line. On Windows, it may be convenient to create a batch (.bat) file that you can run from Explorer (an example is provided). ------------------ 6. FILE FORMATS ------------------ The current version of TCODS supports several simple, human-readable mesh formats. These formats are described in the file FORMATS.txt. Additional formats can be added by modifying the MeshIO class and the Mesh::read() method in HalfEdge.cpp. ----------------- 7. SOURCE CODE ----------------- As an alternative to the command-line utility, you can of course interface with the code directly. I've done my best to clean up and comment, but (as already noted) the code evolved along with the research, so be prepared for some funkiness! Basic usage can be seen in the method Problem::solve() from Problem.cpp. For instance, here's how you might put a few arbitrary singularities on a bunny mesh: Mesh mesh; mesh.read( "bunny.obj" ); // read a polygon mesh mesh.vertex( 0 )->k = 1.; // specify some singularities mesh.vertex( 100 )->k = .5; mesh.vertex( 200 )->k = .5; mesh.fieldAngle = 1.23; // specify the field direction mesh.computeTrivialConnection(); // compute the solution mesh.write( "hairybunny.eobj" ); // write the mesh plus direction field The code also includes basic support for generating integral curves of the direction field in Mesh::integralCurve() (see HalfEdge.h). For instance, the following code will compute a single integral curve starting at the center of the first face of the mesh in an arbitrary direction: vector<Vector> curve, normals; FaceIter f = mesh.faces.begin(); double initialAngle = 0.; Vector initialPoint = f->toLocal( f->barycenter() ); mesh.integralCurve( initialFace, initialPoint, initialAngle, curve, normals ); The resulting vectors "curve" and "normals" contain lists of positions and surface normals along the curve. This routine uses piecewise linear interpolation of the direction field and may not produce nice results in highly singular regions. ------------- 8. LICENSE ------------- TCODS is covered by the following free software license based on the 2-clause BSD license. This license is compatible with most other free software licenses, including the GNU General Public License. * * Copyright 2010 Keenan Crane. All rights reserved. * * Redistribution and use in source and binary forms, with or without modification, * are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT * SHALL THE FREEBSD PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * * The views and conclusions contained in the software and documentation are those * of the author and should not be interpreted as representing official policies, * either expressed or implied, of any other person or institution. *
About
Mirror repository for Keenan Crane's trivial connection https://www.cs.cmu.edu/~kmcrane/Projects/TrivialConnections/
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published