Skip to main content

fullcontrol - unconstrained design

Project description

FullControl

FullControl - unconstrained design

fullcontrol allows you to control 3D printers, or other cnc systems, in ways that are not possible using conventional software

you design everything about the print path and print settings, giving you the design freedom to do anything you want

get started without installing anything: go through the interactive tutorial notebooks then use the design template - or install and run things locally as described below

(youtube playlist)


think beyond 'normal' 3D printing

intro

the conventional method to generate gcode is: create cad model -> export stl -> slice into layers -> create paths for each layer -> output path as gcode

FullControl offers a different approach where the print path is explicitly designed. imagine being given a hotmelt glue-gun and told to move it around to 'print' layers resulting in a 30-mm cube. you could design lots of different paths that would achieve the cube. FullControl allows you to design and preview print paths and convert them to machine-code instructions for a 3D printer (a gcode file)

the overall printing procedure may be considered to be predominantly a stream of points. then a few extra things are sprinkled in occasionally, like changes to speed, temperature, fans, etc.

all of these things together (points and the extra things) are referred to as state in FullControl. state is basically any property of interest that can change

FullControl allows designs to be created that control changes the state of things, where things are anything with state - this initial release of FullControl is focused on the thing being an extrusion 3D printer that is instructed by gcode. however, things really could be anything (laser cutters, assembly lines, non-physical things like a 3D visualization, etc.)

FullControl history

"FullControl gcode designer" (2020) (website, github, journal paper)

  • users generate gcode by directly designing geometric 'features' and custom gcode 'features'
  • microsoft excel used as the user interface for design creation. FullControl algorithms written in visual basic. gcode previewed in other software (e.g. repetier host)
  • targeted researchers and people experimenting with printers and other gcode-based hardware, who need to explicitly design print paths with 'full control'

"www.fullcontrol.xyz" (2022):

  • users generate and download gcode parametrically for pre-created designs directly from a website
  • no need for experience of printing, gcode, CAD, toolpath design, python, etc.
  • demo models created with the python implementation of FullControl (i.e. this repository)

"FullControl" (2023) - this repository:

  • users design, preview, and export gcode for custom print paths for extrusion 3D printing, all in a python environment
  • 'designs' are python scripts or jupyter notebooks
  • the initial release (March 2023) is a gcode-focused implementation of the broader FullControl concept to design changes to the state of things

using FullControl

jupyter notebooks are provided in the tutorials folder of this github repository (repo) to introduce FullControl and demonstrate its use - browse tutorials: github / colab

you can either use a cloud-based jupyter notebook environment like google colab, or run things locally by installing python and then either jupyterlab or vscode with python and jupyter extensions

a future update of this repo will give more details about the python code

installation

new to python? don't install - just use the colab design template and get designing straight away online

alternatively, to run locally, install miniconda/anaconda/python and git - if you run into any installation problems, update your versions of python/git/pip

pip install git+https://github.com/FullControlXYZ/fullcontrol

you can also clone this git repo and run "pip install ." from the repo directory

use

to use FullControl, create a python script or jupyter notebook and import the fullcontrol package

import fullcontrol as fc

structure of the repository

the FullControl repository is organized as follows:

  • tutorials: jupyter notebooks describing FullControl and its use. For more details, check the readme here or jump straight in to the 1-minute demo
  • fullcontrol: the FullControl python package. For more details, check the readme here
  • models: example models that use FullControl. For more details, check the readme here
  • lab: the FullControl lab python package for experimental features. For more details, check the readme here
  • bin: scripts for FullControl development activities

workflow for new content

the anticipated workflow for new content is:

  1. demonstrate new ideas with github gists (quick and dirty)
  2. gists inform new additions to the FullControl lab (a little more polished)
  3. lab informs new additions to the main fullcontrol package or models subdirectory

feedback

please use the github issues tab for this repository to give feedback.

pull requests

please submit pull requests for bugfixes, optimizations, documentation corrections/clarifications, etc., and for minor additions and new features such as functions, objects, and modules that fit into the existing package structure

for revisions that change the structure, behaviour, or usage of the software, please email us (info@fullcontrol.xyz) prior to submitting a pull request. this is to ensure alignment between the changes and any planned/unpublished revisions already in progress. note that this version of FullControl is not targeted at developers - the structure of the repo may change and more information about the code structure will be provided at a later date to accommodate contribution more readily

note that the tutorials folder of this repo contains tutorial notebooks. executing cells in these notebooks leads to timestamp changes, even if the cell content remains unchanged. this may cause unexpected issues and complications for pull requests. until a more automated solution is implemented, consider two options before submitting a pull request:

  1. create a fresh clone of the FullControl repo and copy the relevant changes across (recommended)
  2. use the git stash operation on the tutorials folder (be careful not to unintentionally stash any of your proper changes though)

license

FullControl is released under the GPL v3 License.

copyright

FullControl, FullControlXYZ, copyright 2023 Andrew Gleadall and Dirk Leas

references

until the journal paper for FullControl is available, please cite the paper for 'FullControl GCode Designer':

Gleadall, A. (2021). FullControl GCode Designer: open-source software for unconstrained design in additive manufacturing. Additive Manufacturing, 46, 102109.

contact

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fullcontrol-0.1.2.tar.gz (3.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fullcontrol-0.1.2-py3-none-any.whl (653.3 kB view details)

Uploaded Python 3

File details

Details for the file fullcontrol-0.1.2.tar.gz.

File metadata

  • Download URL: fullcontrol-0.1.2.tar.gz
  • Upload date:
  • Size: 3.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.3

File hashes

Hashes for fullcontrol-0.1.2.tar.gz
Algorithm Hash digest
SHA256 3dccc2f45bf641386ee5fe80438d7857f63f835a314e157074f5142b806e2180
MD5 82ed8d3b7dc00b8f8674fcf97182dc3c
BLAKE2b-256 0b4f814b9dc188a51474e08e18b325a7933ea7d2157fbe929bbc061e23297aa5

See more details on using hashes here.

File details

Details for the file fullcontrol-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: fullcontrol-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 653.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.3

File hashes

Hashes for fullcontrol-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 378ec36be96eaa41f63e0d9950d5d3f46f8a9a5d869943ad290f33ae5a92a19c
MD5 c3635cbab53bcffae5951dc93e910a57
BLAKE2b-256 aba7f8ae8a49ca5befb395fc4896b7d6433d2aa78955c08b8792021ad55684a8

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page