diff --git a/013_interferences.ipynb b/013_interferences.ipynb index 72b6a38..e86dae4 100644 --- a/013_interferences.ipynb +++ b/013_interferences.ipynb @@ -132,25 +132,21 @@ " window2=0.05,\n", " max_atoms=2,\n", " max_charge=2):\n", - " try:\n", - "\n", - " elements = [el.strip() for el in elements.strip(',').split(',')]\n", + " \n", + " elements = [el.strip() for el in elements.strip(',').split(',')]\n", "\n", - " if window1:\n", - " window = (window1, window2)\n", - " else:\n", - " window=None\n", - " df = build_table(elements,\n", - " window=window,\n", - " max_atoms=max_atoms,\n", - " charges=[i+1 for i in range(max_charge)])\n", - " print(\"Table size: {}\".format(df.index.size))\n", - " display(df.style.background_gradient(cmap=\"Blues\",\n", - " axis=0,\n", - " subset=pd.IndexSlice[:, ['iso_product']])\n", - " )\n", - " except:\n", - " pass\n", + " window = None\n", + " if window1 is not None:\n", + " if window1.strip():\n", + " window = (window1, window2)\n", + " df = build_table(elements,\n", + " window=window,\n", + " max_atoms=max_atoms,\n", + " charges=[i+1 for i in range(max_charge)])\n", + " print(\"Table size: {}\".format(df.index.size))\n", + " return display(df.style.background_gradient(cmap=\"Blues\",\n", + " axis=0,\n", + " subset=pd.IndexSlice[:, ['iso_product']]))\n", "mode= widgets.ToggleButtons(options=['spectra','stemplot'], value='spectra', description='Mode:')\n", "elements=widgets.Text(value=\"C,B,N,O\",description='Elements:')\n", "max_atoms=widgets.IntSlider(min=1, max=3, step=1, value=2,\n", @@ -217,6 +213,7 @@ " max_labels=n_labels, \n", " figsize=(8, 4),\n", " iter_lim=10)\n", + " return ax.figure\n", " except:\n", " pass\n", "\n", diff --git a/014_autopew.ipynb b/014_autopew.ipynb index 6eda76e..5fdab1c 100644 --- a/014_autopew.ipynb +++ b/014_autopew.ipynb @@ -32,17 +32,42 @@ " \n", "> Automating sample targeting for geological microanalysis systems.\n", "\n", + "`autopew` is designed for arbitrary translation between planar/2D Cartesian coordinate systems using affine transforms and human-in-the-loop workflows.\n", "\n", - "| | | \n", + "This is applied to integrating coordinate systems across analytical instrumentation, with each instrument typically having its own individual coordinate systems based on imagery and/or a sample stage. autopew also includes functions for importing and exporting files, for automated generation of point sets within a relevant format for each piece of analytical instrumentation. For example, `autopew` outputs currently included a `.scancsv` file which can be directly imported into Chromium laser ablation navigation software.\n", + "\n", + "### Why use autopew?\n", + "\n", + "`autopew` is designed for easy referencing between analytical equipment and/or images. This allows the time spend on analytical equipment to be more effectively used for data collection rather than spending valuable time locating the areas of interest (at least where this functionality doesn't already exist). Although primarily designed for use of laser ablation analysis on geological material this software can be used for any microanalytical technique, including electron microprobe analysis, x-ray fluorescence mapping, scanning electron microscopy and ion beam analysis.\n", + "\n", + "### What does it look like?\n", + "\n", + "| | | \n", "|:---:|:---:|\n", - "| | |\n", "| A back-scattered electron image of a 25mm diameter round rock sample. The sample contains sulfide as the very bright phases and spinel in mid-grey tones. Three grains were used for reference coordinates and marked on the image. | Analysis locations can be chosen as pixel coordinates on the image. ``autopew`` allows for zoom and pan to allow extremely precise placement. This image was saved directly from autopew. |\n", "\n", "\n", - "| |\n", - "|:--:|\n", "| |\n", - "| The transformation can be visualised to quickly determine if it is reasonable or if more reference points are required. Here reference points used are circled, sample coordiantes are connected to their transformed quivalents, and a convex hull is used to illustrate the outer bounds of the coordinates used. Note the change in coordinate magnitudes and sign from the pixels (left) to stage coordinates (right). |" + "|:--:|\n", + "| The transformation can be visualized to quickly determine if it is reasonable or if more reference points are required. Here reference points used are circled, sample coordinates are connected to their transformed equivalents, and a convex hull is used to illustrate the outer bounds of the coordinates used. Note the change in coordinate magnitudes and sign from the pixels (left) to stage coordinates (right). |\n", + "\n", + "### Where might this go?\n", + "\n", + "* **Microanalytical Coordinate System Networks**\n", + "\n", + " One idea for the future of `autopew` is creating and storing information about coordinate systems and transformations betwen them. Through creating connected networks of coordinate systems, the spatial context of analysis across instruments and images can be automatically determined through aggregating or propogating the transformations.\n", + "\n", + "| \n", + "|:---:|\n", + "| Illustrative example of a coordinate system network and propagation of coordinates from an EPMA image to produce coordinates for a LA-ICP-MS stage after transformations have been calibrated (red path).|\n", + "\n", + "* **Generating Outputs for a Variety of Instruments**\n", + "\n", + " Currently `autopew` enables export of coordinates in a few simple formats, and one vendor-specific format (`.scancsv` for Chromium laser ablation navigation software), but where these formats are text based (i.e. not binary proprietary formats) we could readily write reading and writing functions. While the coordinate transforms are relatively format agnostic (as long as it can be read..), these functions are required to make the software practical for use in other labs.\n", + "\n", + "* **3D Affine Transforms to Keep Focus/Surface Height Context**\n", + "\n", + " Currently `autopew` only works in 2D, but with a bit of an upgrade we could also store 3D coordinate systems including a 'focus' or z coordinate which are useful for microscale analysis (e.g. especially SIMS). This could probably be implements as 2D + a 1D tilt, given we are typically working on approximately 2D surfaces. " ] }, { @@ -58,6 +83,13 @@ "| | | [interferences](./013_interferences.ipynb) | \n", "| | | [autopew](./014_autopew.ipynb) | " ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [] } ], "metadata": { diff --git a/binder/environment.yml b/binder/environment.yml index 5e7ca2f..a574641 100644 --- a/binder/environment.yml +++ b/binder/environment.yml @@ -13,7 +13,7 @@ dependencies: - ipyvolume - widgetsnbextension - imagemagick - - jupytext + - prompt-toolkit=3.0.4 # 3.0.5 broken on conda - pip: - jupyter_contrib_nbextensions - -e git+git://github.com/morganjwilliams/pyrolite.git@develop#egg=pyrolite[skl]