quool


Namequool JSON
Version 7.0.1 PyPI version JSON
download
home_pageNone
SummaryQuantitative Toolkit - a helper in quant developing
upload_time2024-12-27 03:20:06
maintainerNone
docs_urlNone
authorNone
requires_pythonNone
licenseNone
keywords quant framework finance
VCS
bugtrack_url
requirements bs4 lxml tqdm numpy joblib pandas retrying requests matplotlib backtrader
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Quool

Quool is a Python framework designed specifically for quantitative investment research. It aims to provide a flexible and efficient set of tools to help researchers and developers quickly implement data management, factor analysis, trading recording, and strategy evaluation functionalities. With Quool, users can focus on strategy and factor research without spending excessive time on data management and infrastructure setup.

## Features

- **Data Management**: Offers a unified interface for managing and accessing financial market data, supporting both intraday and daily data processing.
- **Factor Research**: Simplifies the process of factor development and testing, supporting factor definition, storage, analysis, and performance evaluation.
- **Trading Recording**: Provides flexible Recorder classes for recording and managing trade data and model execution data.
- **Strategy Evaluation**: Integrates strategy evaluation tools, supporting calculations of various performance metrics and result visualization.

## Installation

Currently, the Quool framework is not available on PyPI. You can install it from the source code as follows:

```bash
git clone https://github.com/your-username/quool.git
cd quool
pip install .
```

## Quick Start

Here are the basic steps to conduct factor research and strategy evaluation using Quool:

### Define a Factor

First, inherit the `BaseFactor` class to define your own factor. For example, define a factor that calculates the Volume Weighted Average Price (VWAP):

```python
from quool import BaseFactor

class VWAPFactor(BaseFactor):
    def get_vwap(self, date: pd.Timestamp):
        # Implement the calculation logic for VWAP
        pass
```

### Calculate Factor Values

Instantiate your factor class and use the `get` method to calculate factor values for a specific date range:

```python
vwap_factor = VWAPFactor(uri="./path/to/factor/data")
vwap_values = vwap_factor.get("vwap", start="2021-01-01", stop="2021-12-31")
```

### Evaluate Strategies

Use the `TradeRecorder` or other recorder classes to record your trading activities and use the `evaluate` method to assess strategy performance:

```python
from quool import TradeRecorder

# Record trading activities
trade_recorder = TradeRecorder(uri="./path/to/trade/data")
trade_recorder.record(date="2021-01-01", ...)

# Evaluate strategy performance
performance = trade_recorder.evaluate(...)
```

## Contributing

Contributions in the form of issue reports and pull requests are welcome on GitHub.

## License

Quool is released under the MIT license.

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "quool",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "quant, framework, finance",
    "author": null,
    "author_email": "ppoak <ppoak@foxmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/bd/69/bf102e7a93500a3e34ab64a37e3e72a816bc96488ad09416ce3bf13c0785/quool-7.0.1.tar.gz",
    "platform": null,
    "description": "# Quool\n\nQuool is a Python framework designed specifically for quantitative investment research. It aims to provide a flexible and efficient set of tools to help researchers and developers quickly implement data management, factor analysis, trading recording, and strategy evaluation functionalities. With Quool, users can focus on strategy and factor research without spending excessive time on data management and infrastructure setup.\n\n## Features\n\n- **Data Management**: Offers a unified interface for managing and accessing financial market data, supporting both intraday and daily data processing.\n- **Factor Research**: Simplifies the process of factor development and testing, supporting factor definition, storage, analysis, and performance evaluation.\n- **Trading Recording**: Provides flexible Recorder classes for recording and managing trade data and model execution data.\n- **Strategy Evaluation**: Integrates strategy evaluation tools, supporting calculations of various performance metrics and result visualization.\n\n## Installation\n\nCurrently, the Quool framework is not available on PyPI. You can install it from the source code as follows:\n\n```bash\ngit clone https://github.com/your-username/quool.git\ncd quool\npip install .\n```\n\n## Quick Start\n\nHere are the basic steps to conduct factor research and strategy evaluation using Quool:\n\n### Define a Factor\n\nFirst, inherit the `BaseFactor` class to define your own factor. For example, define a factor that calculates the Volume Weighted Average Price (VWAP):\n\n```python\nfrom quool import BaseFactor\n\nclass VWAPFactor(BaseFactor):\n    def get_vwap(self, date: pd.Timestamp):\n        # Implement the calculation logic for VWAP\n        pass\n```\n\n### Calculate Factor Values\n\nInstantiate your factor class and use the `get` method to calculate factor values for a specific date range:\n\n```python\nvwap_factor = VWAPFactor(uri=\"./path/to/factor/data\")\nvwap_values = vwap_factor.get(\"vwap\", start=\"2021-01-01\", stop=\"2021-12-31\")\n```\n\n### Evaluate Strategies\n\nUse the `TradeRecorder` or other recorder classes to record your trading activities and use the `evaluate` method to assess strategy performance:\n\n```python\nfrom quool import TradeRecorder\n\n# Record trading activities\ntrade_recorder = TradeRecorder(uri=\"./path/to/trade/data\")\ntrade_recorder.record(date=\"2021-01-01\", ...)\n\n# Evaluate strategy performance\nperformance = trade_recorder.evaluate(...)\n```\n\n## Contributing\n\nContributions in the form of issue reports and pull requests are welcome on GitHub.\n\n## License\n\nQuool is released under the MIT license.\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Quantitative Toolkit - a helper in quant developing",
    "version": "7.0.1",
    "project_urls": {
        "Homepage": "https://github.com/ppoak/quool"
    },
    "split_keywords": [
        "quant",
        " framework",
        " finance"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "d102a08072c9885a7723bd8741b5181ddca8a4dec10481b5174cfd8f89e3c47b",
                "md5": "bc8448c05822ecea6820f420527b7a68",
                "sha256": "e71f20f8f00f7cd34c96d8d0c85aa8e4056dd41bc4c5a30dd521ee4986b0a9c2"
            },
            "downloads": -1,
            "filename": "quool-7.0.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "bc8448c05822ecea6820f420527b7a68",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 20702,
            "upload_time": "2024-12-27T03:20:04",
            "upload_time_iso_8601": "2024-12-27T03:20:04.222117Z",
            "url": "https://files.pythonhosted.org/packages/d1/02/a08072c9885a7723bd8741b5181ddca8a4dec10481b5174cfd8f89e3c47b/quool-7.0.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "bd69bf102e7a93500a3e34ab64a37e3e72a816bc96488ad09416ce3bf13c0785",
                "md5": "c6d09f75ab6ce951dfc41e994b84f02a",
                "sha256": "efd2d9185ad445ea265c8ff4a6e63eb25a71e94eb07fe6509d9a89286fa809cb"
            },
            "downloads": -1,
            "filename": "quool-7.0.1.tar.gz",
            "has_sig": false,
            "md5_digest": "c6d09f75ab6ce951dfc41e994b84f02a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 20919,
            "upload_time": "2024-12-27T03:20:06",
            "upload_time_iso_8601": "2024-12-27T03:20:06.559065Z",
            "url": "https://files.pythonhosted.org/packages/bd/69/bf102e7a93500a3e34ab64a37e3e72a816bc96488ad09416ce3bf13c0785/quool-7.0.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-12-27 03:20:06",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "ppoak",
    "github_project": "quool",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "requirements": [
        {
            "name": "bs4",
            "specs": []
        },
        {
            "name": "lxml",
            "specs": []
        },
        {
            "name": "tqdm",
            "specs": []
        },
        {
            "name": "numpy",
            "specs": []
        },
        {
            "name": "joblib",
            "specs": []
        },
        {
            "name": "pandas",
            "specs": []
        },
        {
            "name": "retrying",
            "specs": []
        },
        {
            "name": "requests",
            "specs": []
        },
        {
            "name": "matplotlib",
            "specs": []
        },
        {
            "name": "backtrader",
            "specs": []
        }
    ],
    "lcname": "quool"
}
        
Elapsed time: 0.51683s