From 687b6002345e199a6769893afa0547dd00033f58 Mon Sep 17 00:00:00 2001 From: toubol <38464071+toubol@users.noreply.github.com> Date: Mon, 28 May 2018 13:42:33 +0200 Subject: [PATCH 1/6] solving issue #179 --- pycorrfit/gui/plotting.py | 26 +++++++++++++++++++++++--- 1 file changed, 23 insertions(+), 3 deletions(-) diff --git a/pycorrfit/gui/plotting.py b/pycorrfit/gui/plotting.py index 52951bce..ce4b377c 100644 --- a/pycorrfit/gui/plotting.py +++ b/pycorrfit/gui/plotting.py @@ -7,6 +7,7 @@ import matplotlib import numpy as np +import re # We do catch warnings about performing this before matplotlib.backends stuff with warnings.catch_warnings(): @@ -70,6 +71,7 @@ def latexmath(string): unicodechars["³"] = r"^3" unicodechars["₁"] = r"_1" unicodechars["₂"] = r"_2" + unicodechars["₃"] = r"_3" unicodechars["₀"] = r"_0" #unicodechars["α"] = r"\alpha" # We need lambda in here, because unicode names it lamda sometimes. @@ -107,6 +109,24 @@ def latexmath(string): return anew + r" \hspace{0.3em} \mathrm{"+b+r"}" +def genLatexText(parm, labels): + """Generate the LaTeX text for the plot with handling multiple underscores + in the labels. + """ + for i in np.arange(len(parm)): + line = r' {} &= {:.3g} \\'.format(latexmath(labels[i]), parm[i]) + match = re.search(r'\\text\{(.*?)\}', line) + if match: + if '_' in match.groups()[0]: + tmpstr = match.groups()[0].split('_') + if ''.join(tmpstr).isnumeric(): + line = line.replace(match.groups()[0], ''.join(tmpstr)) + elif len(tmpstr) == 2: + tmpstr = '$_'.join(tmpstr) + '$' + line = line.replace(match.groups()[0], tmpstr) + yield line + + def savePlotCorrelation(parent, dirname, Page, uselatex=False, verbose=False, show_weights=True): """ Save plot from Page into file @@ -218,8 +238,8 @@ def savePlotCorrelation(parent, dirname, Page, uselatex=False, text += r'\[' #every line is a separate raw string... text += r'\begin{split}' # ...but they are all concatenated # by the interpreter :-) - for i in np.arange(len(parms)): - text += r' {} &= {:.3g} \\'.format(latexmath(labels[i]), parms[i]) + for line in genLatexText(parms, labels): + text += line ## According to issue #54, we remove fitting errors from plots #if errparms is not None: # keys = errparms.keys() @@ -422,4 +442,4 @@ def savePlotTrace(parent, dirname, Page, uselatex=False, verbose=False): pass # set dpi to 300 -matplotlib.rcParams['savefig.dpi'] = 300 \ No newline at end of file +matplotlib.rcParams['savefig.dpi'] = 300 From 0b930ed30c919db707b22993ed94bf2233865138 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Paul=20M=C3=BCller?= Date: Mon, 28 May 2018 23:00:53 +0200 Subject: [PATCH 2/6] docs: update contributer information --- docs/sec_contribute.rst | 85 ++++++++++++++++++++++++++++++----------- 1 file changed, 62 insertions(+), 23 deletions(-) diff --git a/docs/sec_contribute.rst b/docs/sec_contribute.rst index c4601478..6a99ab5f 100644 --- a/docs/sec_contribute.rst +++ b/docs/sec_contribute.rst @@ -33,42 +33,81 @@ the PyCorrFit issue page on GitHub such that we may coordinate a pull request. +For documentation writers +========================= +To build this documentation, fork PyCorrFit, navigate +to the `docs` (not `doc`) directory and run. + +- ``pip install -r requirements`` followed by +- ``sphinx-build . _build``. + +This will create the html documentation on your computer. Syntax warnings and errors +will be displayed during the build (there should be none). After making your +changes to your forked branch, create a pull request in GitHub. + +If you only found a typo or wish to make text-only changes, you can also +use the GitHub interface to edit the files (without testing the build +step on your computer). + + For developers ============== -If you would like to know how a contribution to PyCorrFit should look -like, please create an issue on GitHub and I will update this part -of the documentation. - Running from source ------------------- -The easiest way to run PyCorrFit from source is to use -`Anaconda `_. PyCorrFit requires wxPython which is not -available at the Python package index. Make sure you install a unicode version of wxPython. -Detailed installation instructions are `here `_. - - -Contributing ------------- -The main branch for developing PyCorrFit is *develop*. Small changes that do not -break anything can be submitted to this branch. -If you want to do big changes, please (fork ShapeOut and) create a separate branch, -e.g. ``my_new_feature_dev``, and create a pull-request to *develop* once you are done making -your changes. -Please make sure to also update the -`changelog `_. - -Tests ------ +It is recommended to work with +`virtual environments `_. + +Windows +~~~~~~~ +The easiest way to run PyCorrFit from source on Windows is +`Anaconda `_. + +- ``conda install matplotlib numpy pip scipy wxpython`` +- ``pip install cython wheel simplejson sympy lmfit`` +- ``pip install -e . # in the root directory of the repository`` + +Ubuntu 17.10 +~~~~~~~~~~~~ +PyCorrFit requires wxPython >= 4.0.1 which is not available as a binary +wheel on PyPI and thus must be built from the .tar.gz. +Install all dependencies (https://github.com/wxWidgets/Phoenix/blob/master/README.rst): + +- ``pip install cython matplotlib lmfit numpy scipy sympy`` +- ``sudo apt-get install -qq libgtk2.0 libgtk2.0-dev libwebkitgtk-dev dpkg-dev build-essential python3.6-dev libjpeg-dev libtiff-dev libsdl1.2-dev libnotify-dev freeglut3 freeglut3-dev libsm-dev libgtk-3-dev libwebkit2gtk-4.0-dev libxtst-dev libgstreamer-plugins-base1.0-dev`` +- ``pip install wxPython # this will take some time`` +- ``pip install -e . # in the root directory of the repository`` + +Testing +------- PyCorrFit is tested using pytest. If you have the time, please write test methods for your code and put them in the ``tests`` directory. You may -run the tests manually by issuing: +run all tests by issuing: :: python setup.py test +Pull request guidelines +----------------------- +Please fork PyCorrFit and create a pull request (PR) introducing your changes. + +- A new PR should always be made into the `develop` branch. +- If a PR introduces a new functionality or fixes a bug, it should provide + a test case, i.e. a new file or function in the `tests` directory + (see `here `_ + for examples). + Note that currently there is no recipe for testing the graphical user + interface code. +- New code should follow the + `Style Guide for Python Code `_. + Please use `flake8 `_ + to check the files you changed or created. +- New code should be documented well. +- Make sure to update the `changelog `_. + + Windows test binaries --------------------- After each commit to the PyCorrFit repository, a binary installer is created From 70b05a22e3dba5bae86a35f03763076ca4e6a240 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Paul=20M=C3=BCller?= Date: Tue, 29 May 2018 10:19:50 +0200 Subject: [PATCH 3/6] docs: typo --- docs/sec_contribute.rst | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/docs/sec_contribute.rst b/docs/sec_contribute.rst index 6a99ab5f..73e4457a 100644 --- a/docs/sec_contribute.rst +++ b/docs/sec_contribute.rst @@ -38,12 +38,12 @@ For documentation writers To build this documentation, fork PyCorrFit, navigate to the `docs` (not `doc`) directory and run. -- ``pip install -r requirements`` followed by +- ``pip install -r requirements.txt`` followed by - ``sphinx-build . _build``. This will create the html documentation on your computer. Syntax warnings and errors will be displayed during the build (there should be none). After making your -changes to your forked branch, create a pull request in GitHub. +changes to your forked branch, create a pull request on GitHub. If you only found a typo or wish to make text-only changes, you can also use the GitHub interface to edit the files (without testing the build @@ -101,7 +101,7 @@ Please fork PyCorrFit and create a pull request (PR) introducing your changes. Note that currently there is no recipe for testing the graphical user interface code. - New code should follow the - `Style Guide for Python Code `_. + `style guide for Python `_. Please use `flake8 `_ to check the files you changed or created. - New code should be documented well. @@ -113,5 +113,6 @@ Windows test binaries After each commit to the PyCorrFit repository, a binary installer is created by `Appveyor `_. Click on a build and navigate to ``ARTIFACTS`` (upper right corner right under -the running time of the build). From there you can download the Windows installer of the commit. +the running time of the build). From there you can download the Windows +installer for the commit. From 21718707f74ad2fb88d8b38ec0ffb6e0f4dcb361 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Paul=20M=C3=BCller?= Date: Tue, 29 May 2018 21:32:19 +0200 Subject: [PATCH 4/6] cleanup --- pycorrfit/gui/misc.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pycorrfit/gui/misc.py b/pycorrfit/gui/misc.py index d4191804..53402466 100644 --- a/pycorrfit/gui/misc.py +++ b/pycorrfit/gui/misc.py @@ -108,6 +108,6 @@ def getMainIcon(pxlength=32): image = wx.Bitmap.ConvertToImage(iconBMP) image = image.Scale(pxlength, pxlength, wx.IMAGE_QUALITY_HIGH) iconBMP = wx.Bitmap(image) - iconICO = wx.Icon(iconBMP) # wx.Bitmap.ConvertToImage(iconBMP) + iconICO = wx.Icon(iconBMP) return iconICO From 7d8a94e5372d79178738716aa6359dcadcb7442b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Paul=20M=C3=BCller?= Date: Tue, 29 May 2018 21:37:28 +0200 Subject: [PATCH 5/6] ref: remove for-loop --- pycorrfit/gui/plotting.py | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/pycorrfit/gui/plotting.py b/pycorrfit/gui/plotting.py index ce4b377c..22b095be 100644 --- a/pycorrfit/gui/plotting.py +++ b/pycorrfit/gui/plotting.py @@ -113,6 +113,7 @@ def genLatexText(parm, labels): """Generate the LaTeX text for the plot with handling multiple underscores in the labels. """ + text = r'' for i in np.arange(len(parm)): line = r' {} &= {:.3g} \\'.format(latexmath(labels[i]), parm[i]) match = re.search(r'\\text\{(.*?)\}', line) @@ -124,7 +125,8 @@ def genLatexText(parm, labels): elif len(tmpstr) == 2: tmpstr = '$_'.join(tmpstr) + '$' line = line.replace(match.groups()[0], tmpstr) - yield line + text += line + return text def savePlotCorrelation(parent, dirname, Page, uselatex=False, @@ -235,11 +237,9 @@ def savePlotCorrelation(parent, dirname, Page, uselatex=False, # Add some nice text: if uselatex == True and len(parms) != 0: text = r"" - text += r'\[' #every line is a separate raw string... - text += r'\begin{split}' # ...but they are all concatenated - # by the interpreter :-) - for line in genLatexText(parms, labels): - text += line + text += r'\[' + text += r'\begin{split}' + text += genLatexText(parms, labels) ## According to issue #54, we remove fitting errors from plots #if errparms is not None: # keys = errparms.keys() From 0e22840c80d5aa56d275bfdbb2790e347bd4444d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Paul=20M=C3=BCller?= Date: Tue, 29 May 2018 21:42:04 +0200 Subject: [PATCH 6/6] update changelog (close #179) --- CHANGELOG | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG b/CHANGELOG index 68e0de1a..0b8ab764 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,3 +1,6 @@ +1.1.1 + - Fix plotting error with LaTeX (thanks @toubol) (#179) + - Update documentation 1.1.0 - BREAKING CHANGE: Move to Python3 (thanks @toubol) (#173) - GUI: