mini_afsd is a program for controlling a miniaturized additive friction stir deposition (AFSD) machine.
Contents
This repository contains code for controlling a miniaturized AFSD machine and is used by the Yu group at Virginia Tech.
Communication with the machine is achieved using FluidNC, and future modifications to the firmware or code inputs can be helped by looking through FluidNC's documentation.
The LJM driver from LabJack must be installed to interface with the LabJack for measuring the thermocouple outputs, which can be downloaded from https://labjack.com/support/software/installers/ljm.
The driver needed for computers to properly connect to the serial port's USB interface is available from https://oemdrivers.com/usb-cp2104-usb-to-uart-driver. (Change this in the future if the connector changes)
mini_afsd requires Python version 3.10 or later and the following Python libraries:
- labjack-ljm
- NumPy
- matplotlib (>=3.4)
- pyserial
All of the required Python libraries should be automatically installed when installing mini_afsd using any of the installation methods below.
Python can be installed multiple ways:
- If on Windows, the easiest way is to use WinPython. The recommended installation file (as of June 10, 2022) is WinPython64-3.10.4.0 (or WinPython64-3.10.4.0dot if you don't want any preinstalled libraries).
- Use Anaconda, which comes with many libraries preinstalled.
- Install from Python's official source, https://www.python.org/. Follow the instructions listed at https://packaging.python.org/en/latest/tutorials/installing-packages/#requirements-for-installing-packages to ensure Python and the Python package manager pip are correctly installed.
mini_afsd can be installed from pypi using pip, by running the following command in the terminal:
pip install -U mini_afsdThe sources for mini_afsd can be downloaded from the GitHub repo. To install the current version of mini_afsd from GitHub, run:
pip install https://github.com/RyTheGuy355/MiniAFSDCode/zipball/mainWhile not needed, an Arduino IDE (available from https://www.arduino.cc/en/software) can be used when connected to the serial port of the mill to get more detailed feedback on the messages sent to and from the port.
For default usage, mini_afsd can be ran from the a terminal (the command line if Python was install universally, from an Anaconda terminal if Python was installed with Anaconda, or from the WinPython Command Prompt if Python was installed using WinPython) using:
python -m mini_afsdTo list out the various options when using mini_afsd from the terminal, simply do:
python -m mini_afsd -hAlternatively, mini_afsd can be used from a Python file by doing the following:
from mini_afsd import Controller
Controller().run()For determining proper addresses to connections on the LabJack, use the Kipling software included with LJM to find the pin addresses within the "Register Matrix" section.
Commands sent from the GUI to FluidNC for control of the mill can be split into 2 categories:
- G-Code (and subsequent M-Codes, etc.): These are prefixed by "G", "M", etc., and follow their standard usage. See http://wiki.fluidnc.com/en/features/supported_gcodes for the G-Codes supported by FluiNC.
- Codes to FluiNC or Grbl. These can include things liking homing ("$H"), status query ("?"), or soft reset ("0x18" == "CTRL+X"). When adding new commands under this category, it is recommended to add a comment as to what these commands are doing since it is not immediately clear and makes maintenance difficult. A full listing of commands can be found at http://wiki.fluidnc.com/en/features/commands_and_settings.
While the program is running, it is set up to automatically log messages sent and received from the mill for later reference/debugging. In addition, if data collection was turned on and the data was not subsequently saved, the data is automatically saved in order to prevent losing data.
The folder where these logs and data files are saved can be found by running the following within a Python file:
from mini_afsd.controller import get_save_location
print(get_save_location())On Windows, this folder location likely corresponds to the local AppData folder,
ie. %localappdata%/mini_afsd.
mini_afsd is all rights reserved. For more information, refer to the license.
- Ryan Gottwald