Skip to main content

Python package to automate the boring bits of mechanical test data analysis!

Project description

pymechtest

License PyPI Code Style CI

pymechtest is a small, hopefully helpful python package to help engineers collate, process, analyse, and report on mechanical test data. I built pymechtest to help automate the things I did on a near-daily basis as a materials engineer. I hope it can prove some use to you too!

What is it?

:warning: This project should be considered in alpha and may change significantly without deprecation cycles.

Have you ever had to process a bunch of csv output from a mechanical test machine, copying and pasting data into a hacky Excel template to calculate things like elastic modulus and yield strength?

Only to then have to make another Excel file where you create a summary table...

And then have to copy and paste that into a report or an email...

And then you have to plot the data in Excel and spend half an hour tweaking the colours to get it to look at least halfway professional...

And then you discover Excel has formatted your strain column as a date for literally no reason so now your plots have broken...

And then next week you have to do all this again! :angry:

No more! :boom:

pymechtest has a very simple goal: to reduce the amount of time engineers spend munging data after a batch of mechanical testing.

Here is a quick taste of how easy it is to go from raw data to a gorgeous stress-strain plot:

from pymechtest import Tensile

# header and id_row are related to the structure of your csv files
tens = Tensile(folder = "path/to/raw/data", header = 8, id_row = 3)

# Plot a really nice stress-strain curve with Altair
tens.plot_curves()

plot_curves

The key features are:

  • Intuitive: The API is very intuitive, with descriptive methods like plot_curves and summarise
  • Column Autodetection: pymechtest will try to auto-detect which columns correspond to stress and strain, and ask you to clarify if it can't.
  • Sensible Defaults: The API is designed around sensible defaults for things like modulus strain range, whether to expect a yield strength etc.
  • Automatic Calculations: pymechtest will automatically calculate strength, elastic modulus, yield strength etc. for you.
  • Elegant Looking Stress Strain Curves: pymechtest uses altair to plot amazing looking stress strain curves.
  • Reliable: pymechtest uses battle-tested libraries like pandas, numpy and altair to do most of the work. The API is really a domain-specific convenience wrapper. pymechtest also maintains high test coverage.

Installation

pip install pymechtest

I also plan to make a conda package for this, once I've learned how to do it!

Help

An important note about pymechtest

While I've tried to generalise the API to be of use on different formats of raw data, it is impossible to cover every type of format and ensure compatability.

One way you can help is by try it on your data format, and raise an issue or submit a PR implementing your new format!

Project details


Download files

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

Files for pymechtest, version 0.1.4
Filename, size File type Python version Upload date Hashes
Filename, size pymechtest-0.1.4-py2.py3-none-any.whl (25.1 kB) File type Wheel Python version py2.py3 Upload date Hashes View
Filename, size pymechtest-0.1.4.tar.gz (24.1 kB) File type Source Python version None Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring DigiCert DigiCert EV certificate Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page