Skip to content

derb12/MiniAFSDCode

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

83 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mini_afsd

mini_afsd is a program for controlling a miniaturized additive friction stir deposition (AFSD) machine.

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.

Dependencies

Driver Dependencies

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)

Python Dependencies

mini_afsd requires Python version 3.10 or later and the following Python libraries:

All of the required Python libraries should be automatically installed when installing mini_afsd using any of the installation methods below.

Installing Python

Python can be installed multiple ways:

Stable Release

mini_afsd can be installed from pypi using pip, by running the following command in the terminal:

pip install -U mini_afsd

Development Version

The 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/main

Optional Dependencies

While 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_afsd

To list out the various options when using mini_afsd from the terminal, simply do:

python -m mini_afsd -h

Alternatively, 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:

  1. 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.
  2. 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

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%