Giter Site home page Giter Site logo

dlg_monte_carlo's Introduction

DALiuGE Component Project Template

This project template is the starting point for people who want to develop Python based components for the DALiuGE workflow development and execution framework. It contains everything to get you started, including project setup, dependency installation and the actual installation procedure into the DALiuGE environment.

NOTE: This template is based on the excellent work of Bruno Rocha (https://github.com/rochacbruno/python-project-template).

HOW TO USE THIS TEMPLATE

DO NOT FORK this is meant to be used from Use this template feature, which also appears instead of the usual 'Code' button on the top-right of the GitHub repository page.

  1. Click on Use this template
  2. Give your new DALiuGE components project a good, expressive name, but keep is as short as possible. We recommend the start with a dlg_ prefix (e.g. dlg_helloWorld_cmpts), recommendation is to use all lowercase and underscores separation for repo names.
  3. Once you click OK Wait until the first run of CI finishes(!) (Github Actions will process the template and commit to your new repo).
  4. If you want codecov Reports and Automatic Release to PyPI
    On the new repository settings->secrets add your PIPY_API_TOKEN and CODECOV_TOKEN (get the tokens on respective websites)
  5. Then clone your new components project and happy coding!

AGAIN: WAIT until first CI run on github actions before cloning your new project, else some of the features might not work correctly.

What is included in this template?

  • ๐Ÿ–ผ๏ธ Basic Python components use this template or Run make init after cloning to generate a new project based on a template.
  • ๐Ÿ“ฆ A basic setup.py file to provide installation, packaging and distribution for your component.
    Template uses setuptools because it's the de-facto standard for Python packages, you can run make switch-to-poetry later if you want.
  • ๐Ÿค– A Makefile with the most useful commands to install, test, lint, format and release your component. (Try make help)
  • ๐Ÿ“ƒ Documentation structure using mkdocs. This is meant to describe you components, not the template, thus it is pretty much empty to start with.
  • ๐Ÿ’ฌ Auto generation of change log using gitchangelog to keep a HISTORY.md file automatically based on your commit history on every release.
  • ๐Ÿ‹ A simple Containerfile to build a container image for your project.
    Containerfile is a more open standard for building container images than Dockerfile, you can use buildah or docker with this file.
  • ๐Ÿงช Testing structure using pytest
  • โœ… Code linting using flake8
  • ๐Ÿ“Š Code coverage reports using codecov
  • ๐Ÿ›ณ๏ธ Automatic release to PyPI using twine and github actions.
  • ๐ŸŽฏ Entry points to execute your program using python -m <project_name> or $ project_name with basic CLI argument parsing.
  • ๐Ÿ”„ Continuous integration using Github Actions with jobs to lint, test and release your project on Linux and Mac environments.

Also read ABOUT_THIS_TEMPLATE.md and the DALiuGE Component Developers Guide

To contribute to this template please open an issue or fork and send a PULL REQUEST.

project_name

codecov CI Code style: black

project_description

Installation

There are multiple options for the installation, depending on how you are intending to run the DALiuGE engine, directly in a virtual environment (host) or inside a docker container. You can also install it either from PyPI (latest released version).

Install it from PyPI

Engine in virtual environment

pip install dlg_monte_carlo

This will only work after releasing the project to PyPi.

Engine in Docker container

docker exec -t daliuge-engine bash -c 'pip install --prefix=$DLG_ROOT/code dlg_monte_carlo'

Usage

For example the MyComponent component will be available to the engine when you specify

project_name.apps.MyAppDROP

in the AppClass field of a Python Branch component. The EAGLE palette associated with these components are also generated and can be loaded directly into EAGLE. In that case all the fields are correctly populated for the respective components.

dlg_monte_carlo's People

Contributors

pritchardn avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.