Giter Club home page Giter Club logo

libfive's Introduction

libfive

Infrastructure for solid modeling.

(formerly known as mkeeter/ao)

About

libfive is a framework for solid modeling using functional representations.

It includes several layers, ranging from infrastructure to GUI:

  • The libfive shared library contains functions to build, manipulate, and render f-reps. A great deal of work has gone into the meshing algorithm, which produces watertight, manifold, hierarchical, feature-preserving triangle meshes. The library is written in C++ and exposes a C API in libfive.h.
  • libfive-guile is a Guile binding to libfive. It exposes a high-level API to construct shapes, and includes a standard library of shapes, transforms, and CSG operations.
  • Studio is a GUI application in the style of OpenSCAD. It wraps libfive-guile and allows for live-coding of solid models. The interface also includes direct modeling, where the user can push and pull on the model's surface to change variables in the script.

Other projects using libfive

Language bindings

Viewers

License

(c) 2015-2018 Matthew Keeter

Different layers of this project are released under different licenses:

Contact the author to discuss custom development, integration, or commercial support.

Compiling from source

The full system (libfive + libfive-guile + Studio) has been successfully compiled on Mac and Linux.

The libfive kernel builds on MSVC, and should also build with MinGW (though this is untested).

Dependencies

Qt and Guile are optional; if they aren't present, then the Guile bindings and Studio will not be included in the build (and cmake will print a message to that effect).

Mac

With homebrew installed, run

brew install cmake pkg-config eigen libpng qt guile boost

Then, from the libfive folder, run something like:

mkdir build
cd build
cmake -DCMAKE_PREFIX_PATH=/usr/local/Cellar/qt5/5.7.0  ..
make

(adjust based on your Qt installation, and consider using ninja for faster builds.

Ubuntu

Ubuntu 18.04 or later should have all dependencies available through the package manager

sudo apt-get install cmake pkg-config libeigen3-dev libpng-dev libboost-all-dev qtbase5-dev guile-2.2-dev 

Ubuntu releases before 18.04 do not provide guile-2.2-dev, so omit that from the above package install command. To build guile 2.2.3 from source, run

sudo apt-get install libgmp-dev libltdl-dev libunistring-dev libgc-dev libffi-dev pkg-config
wget https://ftp.gnu.org/gnu/guile/guile-2.2.3.tar.gz 
tar -xf guile-2.2.3.tar.gz
cd guile-2.2.3
./configure
make -j4
sudo make install

Ubuntu releases before 17.04 do not have high enough Qt versions, so also omit qtbase5-dev from the above package install command. To install Qt 5.7 or later, use the Qt provided Online Installer: https://www.qt.io/download The installer will prompt for the install path, which defaults to $HOME/Qt.

Building is similar as on Mac: clone the repository, then run something like

mkdir build
cd build
cmake -DCMAKE_PREFIX_PATH=<Qt Install Path>/5.7/gcc_64 ..
make -j4

(adjusting the Qt path to your install location)

Windows (MSVC)

With Visual Studio 2017 installed, run from libfive folder

git clone https://github.com/Microsoft/vcpkg.git
vcpkg\bootstrap-vcpkg.bat
vcpkg\vcpkg install eigen3:x86-windows-static boost:x86-windows-static libpng:x86-windows-static
md build
cd build
cmake -DCMAKE_TOOLCHAIN_FILE="..\vcpkg\scripts\buildsystems\vcpkg.cmake" -DVCPKG_TARGET_TRIPLET="x86-windows-static" -G "Visual Studio 15 2017" ..

Now open build\libfiv.sln and build the solution. Check that libfive-test runs correctly.

libfive's People

Contributors

borodust avatar bradrothenberg avatar doug-moen avatar erikstrand avatar follower avatar fponticelli avatar fros1y avatar igfraga avatar klauslh avatar kyuvi avatar lorac avatar mattgleeson avatar mayjs avatar mkeeter avatar niffler avatar omgitsraven avatar photocyte avatar rcmz avatar ronasuti avatar sfcgeorge avatar speps avatar stuartlynn avatar tachiniererin avatar thehans avatar yitzi2 avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.