qsdsan

Quantitative Sustainable Design (QSD) of sanitation and resource recovery systems.

https://github.com/qsd-group/qsdsan

Science Score: 49.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 8 DOI reference(s) in README
  • Academic publication links
  • Committers with academic emails
    2 of 13 committers (15.4%) from academic institutions
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (13.0%) to scientific vocabulary

Keywords

dynamic-simulations life-cycle-assessment process-modeling quantitative-sustainable-design resource-recovery sanitation sustainability-analysis techno-economic-analysis
Last synced: 6 months ago · JSON representation

Repository

Quantitative Sustainable Design (QSD) of sanitation and resource recovery systems.

Basic Info
  • Host: GitHub
  • Owner: QSD-Group
  • License: other
  • Language: Python
  • Default Branch: main
  • Homepage: https://qsdsan.com
  • Size: 59 MB
Statistics
  • Stars: 33
  • Watchers: 4
  • Forks: 17
  • Open Issues: 3
  • Releases: 0
Topics
dynamic-simulations life-cycle-assessment process-modeling quantitative-sustainable-design resource-recovery sanitation sustainability-analysis techno-economic-analysis
Created over 5 years ago · Last pushed 6 months ago
Metadata Files
Readme Changelog Contributing License Code of conduct

README.rst

====================================================================================
QSDsan: Quantitative Sustainable Design for Sanitation and Resource Recovery Systems
====================================================================================

.. License
.. image:: https://img.shields.io/pypi/l/qsdsan?color=blue&logo=UIUC&style=flat
   :target: https://github.com/QSD-Group/QSDsan/blob/main/LICENSE.txt

.. Tested Python version
.. image:: https://img.shields.io/pypi/pyversions/qsdsan?style=flat
   :target: https://pypi.python.org/pypi/qsdsan

.. PyPI version
.. image:: https://img.shields.io/pypi/v/qsdsan?style=flat&color=blue
   :target: https://pypi.org/project/qsdsan

.. DOI
.. image:: https://img.shields.io/badge/DOI-10.1039%2Fd2ew00455k-blue?style=flat
   :target: https://doi.org/10.1039/d2ew00455k

.. Documentation build
.. image:: https://readthedocs.org/projects/qsdsan/badge/?version=latest
   :target: https://qsdsan.readthedocs.io/en/latest

.. GitHub test and coverage of the main branch
.. image:: https://github.com/QSD-Group/QSDsan/actions/workflows/build-coverage.yml/badge.svg?branch=main
   :target: https://github.com/QSD-Group/QSDsan/actions/workflows/build-coverage.yml

.. Codecov
.. image:: https://codecov.io/gh/QSD-Group/QSDsan/branch/main/graph/badge.svg?token=Z1CASBXEOE
   :target: https://codecov.io/gh/QSD-Group/QSDsan

.. Binder launch of tutorials
.. image:: ./docs/source/images/custom_binder_logo.svg
   :target: https://mybinder.org/v2/gh/QSD-Group/QSDsan-env/main?urlpath=git-pull%3Frepo%3Dhttps%253A%252F%252Fgithub.com%252FQSD-group%252FQSDsan%26urlpath%3Dtree%252FQSDsan%252Fdocs%252Fsource%252Ftutorials%26branch%3Dmain

.. Email subscription form
.. image:: https://img.shields.io/badge/news-subscribe-F3A93C?style=flat&logo=rss
   :target: https://groups.webservices.illinois.edu/subscribe/154591

.. Event calendar
.. image:: https://img.shields.io/badge/events-calendar-F3A93C?style=flat&logo=google%20calendar
   :target: https://qsdsan.readthedocs.io/en/latest/Events.html

.. YouTube video
.. image:: https://img.shields.io/endpoint?color=%23ff0000&label=YouTube%20 @qsd-group&url=https%3A%2F%2Fyoutube-channel-badge-blond.vercel.app%2Fapi%2Fvideos
   :target: https://www.youtube.com/@qsd-group

.. Code of Conduct
.. image:: https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg
   :target: https://qsdsan.readthedocs.io/en/latest/CODE_OF_CONDUCT.html

.. AppVeyor test of the stable branch, not in active use
..
   .. image:: https://img.shields.io/appveyor/build/yalinli2/QSDsan/main?label=build-stable&logo=appveyor
   :target: https://github.com/QSD-Group/QSDsan/tree/stable

|

.. contents::

|

What is ``QSDsan``?
-------------------
``QSDsan`` is an open-source, community-led platform for the quantitative sustainable design (QSD) of sanitation and resource recovery systems [1]_. It is one of a series of platforms that are being developed for the execution of QSD - a methodology for the research, design, and deployment of technologies and inform decision-making [2]_. It leverages the structure and modules developed in the `BioSTEAM `_ platform [3]_ with additional functions tailored to sanitation processes.

As an open-source and impact-driven platform, QSDsan aims to identify configuration combinations, systematically probe interdependencies across technologies, and identify key sensitivities to contextual assumptions through the use of quantitative sustainable design methods (techno-economic analysis and life cycle assessment and under uncertainty). 

All systems developed with ``QSDsan`` are included in the package `EXPOsan `_ - exposition of sanitation and resource recovery systems.

Additionally, another package, `DMsan `_ (decision-making for sanitation and resource recovery systems), is being developed for decision-making among multiple dimensions of sustainability with consideration of location-specific contextual parameters.


Installation
------------
The easiest way is through ``pip``, in command-line interface (e.g., Anaconda prompt, terminal):

.. code::

    pip install qsdsan

If you need to upgrade:

.. code::

    pip install -U qsdsan

or for a specific version (replace X.X.X with the version number):

.. code::

    pip install qsdsan==X.X.X

If you want to install the latest GitHub version at the `main branch `_ (note that you can still use the ``-U`` flag for upgrading):

.. code::

    pip install git+https://github.com/QSD-Group/QSDsan.git


.. note::

   If this doesn't give you the newest ``qsdsan``, try ``pip uninstall qsdsan`` first.

   Also, you may need to update some ``qsdsan``'s dependency package (e.g., ' ``biosteam`` and ``thermosteam``) versions in order for the new ``qsdsan`` to run.


or other fork and/or branch (replace ```` and ```` with the desired fork and branch names)

.. code::

    pip install git+https://github.com//QSDsan.git@


You can also download the package from `PyPI `_.

Note that development of this package is currently under initial stage with limited backward compatibility, please feel free to `submit an issue `_ for any questions regarding package upgrading.

If you want to contribute to ``QSDsan``, please follow the steps in the `Contributing Guidelines `_ section of the documentation to clone the repository. If you find yourself struggle with the installation of QSDsan/setting up the environment, this extended version of `installation instructions `_ might be helpful to you.


Documentation
-------------
You can find tutorials and documents at:

   https://qsdsan.readthedocs.io

All tutorials are written using Jupyter Notebook, you can run your own Jupyter environment, or you can click the ``launch binder`` badge on the top to launch the environment in your browser.

For each of these tutorials, we are also recording videos where one of the QSD group members will go through the tutorial step-by-step. We are gradually releasing these videos on our `YouTube channel `_ so subscribe to receive updates!


About the Authors
-----------------
Please refer to `Contributors `_ section for a list of contributors.


Contributing
------------
Please refer to the `Contributing Guidelines `_ section of the documentation for instructions and guidelines.


Stay Connected
--------------
If you would like to receive news related to the QSDsan platform, you can subscribe to email updates using `this form `_ (don't worry, you will be able to unsubscribe :)). Thank you in advance for your interest!


QSDsan Events
-------------
We will keep this `calendar `_ up-to-date as we organize more events (office hours, workshops, etc.), click on the events in the calendar to see the details (including meeting links).


License Information
-------------------
Please refer to the ``LICENSE.txt`` for information on the terms & conditions for usage of this software, and a DISCLAIMER OF ALL WARRANTIES.


References
----------
.. [1] Li, Y.; Zhang, X.; Morgan, V.L.; Lohman, H.A.C.; Rowles, L.S.; Mittal, S.; Kogler, A.; Cusick, R.D.; Tarpeh, W.A.; Guest, J.S. QSDsan: An integrated platform for quantitative sustainable design of sanitation and resource recovery systems. Environ. Sci.: Water Res. Technol. 2022, 8 (10), 2289-2303. https://doi.org/10.1039/d2ew00455k.

.. [2] Li, Y.; Trimmer, J.T.; Hand, S.; Zhang, X.; Chambers, K.G.; Lohman, H.A.C.; Shi, R.; Byrne, D.M.; Cook, S.M.; Guest, J.S. Quantitative Sustainable Design (QSD): A Methodology for the Prioritization of Research, Development, and Deployment of Technologies. (Tutorial Review) Environ. Sci.: Water Res. Technol. 2022, 8 (11), 2439–2465. https://doi.org/10.1039/D2EW00431C.

.. [3] Cortés-Peña, Y.; Kumar, D.; Singh, V.; Guest, J.S. BioSTEAM: A Fast and Flexible Platform for the Design, Simulation, and Techno-Economic Analysis of Biorefineries under Uncertainty. ACS Sustainable Chem. Eng. 2020, 8 (8), 3302–3310. https://doi.org/10.1021/acssuschemeng.9b07040.


.. Custom launch badges: https://mybinder.readthedocs.io/en/latest/howto/badges.html
.. binder_badge: https://img.shields.io/badge/launch-binder%20%7C%20tutorial-579ACA.svg?logo=

Owner

  • Name: Quantitative Sustainable Design (QSD) Group
  • Login: QSD-Group
  • Kind: organization
  • Email: quantitative.sustainable.design@gmail.com

Tools for quantitative sustainable design (QSD) to guide the research, development, and deployment of technologies and inform decision-making.

GitHub Events

Total
  • Create event: 9
  • Commit comment event: 7
  • Issues event: 7
  • Watch event: 4
  • Delete event: 3
  • Issue comment event: 55
  • Push event: 299
  • Pull request review event: 1
  • Pull request event: 8
  • Fork event: 3
Last Year
  • Create event: 9
  • Commit comment event: 7
  • Issues event: 7
  • Watch event: 4
  • Delete event: 3
  • Issue comment event: 55
  • Push event: 299
  • Pull request review event: 1
  • Pull request event: 8
  • Fork event: 3

Committers

Last synced: 7 months ago

All Time
  • Total Commits: 1,952
  • Total Committers: 13
  • Avg Commits per committer: 150.154
  • Development Distribution Score (DDS): 0.47
Past Year
  • Commits: 113
  • Committers: 4
  • Avg Commits per committer: 28.25
  • Development Distribution Score (DDS): 0.416
Top Committers
Name Email Commits
Yalin z****i@g****m 1,035
Joy Cheung j****4@g****m 490
RaiSaumitra 8****a 286
Smiti Mittal 5****l 33
Victoria Morgan v****n@i****u 28
Ga-Yeong Kim g****5@g****m 28
Jianan Feng j****2@i****u 21
haclohman 6****n 16
lane-to 9****o 6
Steiner p****r@e****h 4
BenGillen1998 b****8@g****m 2
Yoel y****s@g****m 2
lsrowles s****c@g****m 1
Committer Domains (Top 20 + Academic)

Issues and Pull Requests

Last synced: 6 months ago

All Time
  • Total issues: 60
  • Total pull requests: 71
  • Average time to close issues: 3 months
  • Average time to close pull requests: 7 days
  • Total issue authors: 12
  • Total pull request authors: 9
  • Average comments per issue: 2.9
  • Average comments per pull request: 1.39
  • Merged pull requests: 65
  • Bot issues: 0
  • Bot pull requests: 0
Past Year
  • Issues: 4
  • Pull requests: 5
  • Average time to close issues: 18 days
  • Average time to close pull requests: 3 days
  • Issue authors: 4
  • Pull request authors: 3
  • Average comments per issue: 2.5
  • Average comments per pull request: 5.2
  • Merged pull requests: 5
  • Bot issues: 0
  • Bot pull requests: 0
Top Authors
Issue Authors
  • yalinli2 (47)
  • yoelcortes (2)
  • vlmorgan93 (1)
  • hccroll (1)
  • aiical (1)
  • joyxyz1994 (1)
  • jbolorinos (1)
  • pengxiao01 (1)
  • GaYeongKim (1)
  • Clubiy (1)
  • mckfarm (1)
Pull Request Authors
  • yalinli2 (46)
  • joyxyz1994 (12)
  • jiananf2 (6)
  • yoelcortes (4)
  • GaYeongKim (2)
  • BenGillen1998 (2)
  • philthestone (1)
  • stetsonrowles (1)
  • smitimittal (1)
Top Labels
Issue Labels
enhancement (5) documentation (3) task list (3) good first issue (1)
Pull Request Labels

Packages

  • Total packages: 3
  • Total downloads:
    • pypi 405 last-month
  • Total dependent packages: 1
    (may contain duplicates)
  • Total dependent repositories: 1
    (may contain duplicates)
  • Total versions: 80
  • Total maintainers: 1
proxy.golang.org: github.com/qsd-group/qsdsan
  • Versions: 9
  • Dependent Packages: 0
  • Dependent Repositories: 0
Rankings
Dependent packages count: 7.0%
Average: 8.2%
Dependent repos count: 9.3%
Last synced: 6 months ago
proxy.golang.org: github.com/QSD-Group/QSDsan
  • Versions: 9
  • Dependent Packages: 0
  • Dependent Repositories: 0
Rankings
Dependent packages count: 7.0%
Average: 8.2%
Dependent repos count: 9.3%
Last synced: 6 months ago
pypi.org: qsdsan

Quantitative Sustainable Design for sanitation and resource recovery systems

  • Versions: 62
  • Dependent Packages: 1
  • Dependent Repositories: 1
  • Downloads: 405 Last month
Rankings
Dependent packages count: 3.3%
Forks count: 11.0%
Stargazers count: 11.7%
Average: 12.3%
Downloads: 13.5%
Dependent repos count: 22.2%
Maintainers (1)
Last synced: 6 months ago

Dependencies

.github/workflows/build-coverage.yml actions
  • actions/checkout v3 composite
  • actions/setup-python v4 composite
  • codecov/codecov-action v3 composite
.github/workflows/build-only.yml actions
  • actions/checkout v3 composite
  • actions/setup-python v4 composite
requirements.txt pypi
  • SALib >=1.4.5
  • furo *
  • ipywidgets *
  • jupyterlab-widgets *
  • matplotlib <=3.6.0
  • nbsphinx *
  • pandoc *
  • seaborn *
  • sphinx *
  • sphinx-copybutton *
  • sphinx-design *
  • sympy >=1.8
  • widgetsnbextension *
setup.py pypi
  • SALib >=1.4.5
  • biosteam >=2.36.1
  • matplotlib >=3.3.2
  • pandas >=1.3.2
  • scikit-learn *
  • scipy >=1.7.1
  • seaborn *
  • sympy >=1.8
  • thermosteam >=0.32.0