Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow saving of imported mat files as json #42

Merged
merged 2 commits into from
May 14, 2020
Merged

Conversation

Wealing
Copy link
Contributor

@Wealing Wealing commented May 12, 2020

When importing .mat models, the membranePot type is numpy's int16. The change makes it a standard int so that it can be saved as json.

When importing .mat models, the membranePot type is numpy's int16. The change makes it a standard int so that it can be saved as json.
@codecov
Copy link

codecov bot commented May 12, 2020

Codecov Report

Merging #42 into master will not change coverage.
The diff coverage is 100.00%.

Impacted file tree graph

@@           Coverage Diff           @@
##           master      #42   +/-   ##
=======================================
  Coverage   70.92%   70.92%           
=======================================
  Files          46       46           
  Lines        3401     3401           
=======================================
  Hits         2412     2412           
  Misses        989      989           
Impacted Files Coverage Δ
pytfa/io/base.py 92.62% <100.00%> (ø)

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update f1467b2...6b7aa54. Read the comment docs.

@psalvy
Copy link
Member

psalvy commented May 13, 2020

Hi!
Thanks for this contribution. Could you provide more context as to why this is necessary ? I could not reproduce the bug with this MWE:

%run tutorial_basics.py
from pytfa.io.json import save_json_model, load_json_model
save_json_model(mytfa, 'tmp.json')
m = load_json_model('tmp.json')

I indeed see the mat file is decoded as a numpy int, but the encoding of the JSON and decoding casts it directly to a Python int.
Cheers,
Pierre

@psalvy psalvy self-assigned this May 13, 2020
@Wealing
Copy link
Contributor Author

Wealing commented May 13, 2020

It might be a python 3.8 error:

Traceback (most recent call last):
  File "/Users/home/switchdrive/Cadiz/me/code/examples/write_redgem_to_json.py", line 16, in <module>
    save_json_model(model, 'redgem16_error.json')
  File "/Users/home/switchdrive/Cadiz/repos/cobrapy/cobra/io/json.py", line 110, in save_json_model
    json.dump(obj, file_handle, **dump_opts)
  File "/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/json/__init__.py", line 179, in dump
    for chunk in iterable:
  File "/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/json/encoder.py", line 431, in _iterencode
    yield from _iterencode_dict(o, _current_indent_level)
  File "/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/json/encoder.py", line 405, in _iterencode_dict
    yield from chunks
  File "/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/json/encoder.py", line 405, in _iterencode_dict
    yield from chunks
  File "/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/json/encoder.py", line 405, in _iterencode_dict
    yield from chunks
  [Previous line repeated 1 more time]
  File "/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/json/encoder.py", line 438, in _iterencode
    o = _default(o)
  File "/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/json/encoder.py", line 179, in default
    raise TypeError(f'Object of type {o.__class__.__name__} '
TypeError: Object of type int16 is not JSON serializable

@psalvy
Copy link
Member

psalvy commented May 13, 2020

Yes indeed, I found evidence of it here
Can you just change the int casting to float, since potentials are a continuous physical property ? then I'll merge the PR :)
Cheers,
Pierre

@Wealing
Copy link
Contributor Author

Wealing commented May 13, 2020

Ok, good to go!

@psalvy psalvy merged commit 8103a43 into EPFL-LCSB:master May 14, 2020
@psalvy
Copy link
Member

psalvy commented May 14, 2020

Thanks!

psalvy added a commit that referenced this pull request Mar 4, 2021
Bypassing Travis because failing on GLPK not sympy anymore. See PR #49 

* Dev: Incremental update (#29)

* MNT: Pypi details

* MNT: Adding veriable creation logs

* FIX: typo

* FIX: Issue #28, incorrect variable referencing

* TST: adding tests for some of the analysis functions

* FIX: more fixes from #28

* FIX: fixed transport reaction function

* TST: Better tests, with a smaller model for I/O

* TST/FIX: relative<- absolute paths for small_model resources

* FIX: typo in paths to small_model resources for tests

* VER: Bump v0.9.0-b2

* VER: bump to v0.9.1

* Update LICENSE.txt

* Fixing a couple of minor bugs and added new variable class (#35)

Thank you @remidhum 

* FIX: fixed the apply_directionality function

solution.raw dataframe index does not contain the fwd and bwd use variables.

* ENH: added new binary variable class

This class is usefull to deal with inactive reactions in a model.

* ENH: deal with models without an objective function

Objective function is set to Zero (symbol("0") does not work!) if there is no defined objective function

* OOPS: change proper function ...

* FIX: fixed the failing test

As suggested, I added a check to determine what object type is passed.

* MNT: solution object type testing improved

* LIC: Create CLAI

* Name correction (#41)

Thank you for this correction :) Since I copied this from Google scholar, maybe check that they got your name right!
Cheers,
Pierre

* Allow saving of imported mat files as json (#42)

* Allow saving of imported mat files as json

When importing .mat models, the membranePot type is numpy's int16. The change makes it a standard int so that it can be saved as json.

* convert to float

* VER: Bump to 0.9.2

* MNT: removing warnings from deprecated usage of logger.warn

* FIX: metabolite thermo data was not recovered upon serialization

* FIX: Equilibrator update + reqs for building Dockerfile

* FIX: newer pypi version

* FIX: actual newer pypi version

* Update README.rst

* Update utils.py

* Zero import

Co-authored-by: realLCSB <[email protected]>
Co-authored-by: Pierre Salvy <[email protected]>
Co-authored-by: Pierre Salvy <[email protected]>
Co-authored-by: RémiDhum <[email protected]>
Co-authored-by: Daniel F Hernandez <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants