siglab-py 0.1.37__tar.gz → 0.1.50__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of siglab-py might be problematic. Click here for more details.
- {siglab_py-0.1.37 → siglab_py-0.1.50}/PKG-INFO +1 -1
- {siglab_py-0.1.37 → siglab_py-0.1.50}/pyproject.toml +1 -1
- {siglab_py-0.1.37 → siglab_py-0.1.50}/setup.cfg +1 -1
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/ccxt_candles_ta_to_csv.py +2 -1
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/util/market_data_util.py +6 -6
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py.egg-info/PKG-INFO +1 -1
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/constants.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/exchanges/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/exchanges/any_exchange.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/exchanges/futubull.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/aggregated_orderbook_provider.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/candles_provider.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/candles_ta_provider.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/deribit_options_expiry_provider.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/futu_candles_ta_to_csv.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/orderbooks_provider.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/test_provider.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/ordergateway/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/ordergateway/client.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/ordergateway/encrypt_keys_util.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/ordergateway/gateway.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/ordergateway/test_ordergateway.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/tests/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/tests/integration/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/tests/integration/market_data_util_tests.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/tests/unit/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/tests/unit/analytic_util_tests.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/tests/unit/market_data_util_tests.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/util/__init__.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/util/analytic_util.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/util/aws_util.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/util/retry_util.py +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py.egg-info/SOURCES.txt +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py.egg-info/dependency_links.txt +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py.egg-info/requires.txt +0 -0
- {siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py.egg-info/top_level.txt +0 -0
|
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
|
|
|
4
4
|
|
|
5
5
|
[project]
|
|
6
6
|
name = "siglab_py"
|
|
7
|
-
version = "0.1.
|
|
7
|
+
version = "0.1.50"
|
|
8
8
|
description = "Market data fetches, TA calculations and generic order gateway."
|
|
9
9
|
authors = [{name = "r0bbarh00d", email = "r0bbarh00d@gmail.com"}]
|
|
10
10
|
license = {text = "MIT"}
|
{siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/ccxt_candles_ta_to_csv.py
RENAMED
|
@@ -26,7 +26,7 @@ from siglab_py.util.analytic_util import compute_candles_stats
|
|
|
26
26
|
'''
|
|
27
27
|
Usage:
|
|
28
28
|
set PYTHONPATH=%PYTHONPATH%;D:\dev\siglab\siglab_py
|
|
29
|
-
python ccxt_candles_ta_to_csv.py --exchange_name bybit --symbol BTC/USDT:USDT --end_date "2025-03-
|
|
29
|
+
python ccxt_candles_ta_to_csv.py --exchange_name bybit --symbol BTC/USDT:USDT --end_date "2025-03-25 0:0:0" --start_date "2021-03-11 0:0:0" --default_type linear --compute_ta Y --pypy_compatible N
|
|
30
30
|
|
|
31
31
|
(Remember: python -mpip install siglab_py)
|
|
32
32
|
|
|
@@ -225,6 +225,7 @@ async def main():
|
|
|
225
225
|
boillenger_std_multiples=param['boillenger_std_multiples'],
|
|
226
226
|
sliding_window_how_many_candles=param['ma_long_intervals'],
|
|
227
227
|
slow_fast_interval_ratio=(param['ma_long_intervals']/param['ma_short_intervals']),
|
|
228
|
+
hurst_exp_window_how_many_candles=param['ma_short_intervals'],
|
|
228
229
|
pypy_compat=param['pypy_compatible']
|
|
229
230
|
)
|
|
230
231
|
compute_candles_stats_elapsed_ms = int((time.time() - start) *1000)
|
|
@@ -19,9 +19,9 @@ from siglab_py.exchanges.futubull import Futubull
|
|
|
19
19
|
|
|
20
20
|
def timestamp_to_datetime_cols(pd_candles : pd.DataFrame):
|
|
21
21
|
pd_candles['timestamp_ms'] = pd_candles['timestamp_ms'].apply(
|
|
22
|
-
lambda x: int(x.timestamp()) if isinstance(x, pd.Timestamp) else (int(x
|
|
22
|
+
lambda x: int(x.timestamp()) if isinstance(x, pd.Timestamp) else (int(x) if len(str(int(x)))==13 else int(x*1000))
|
|
23
23
|
)
|
|
24
|
-
pd_candles['datetime'] = pd_candles['timestamp_ms'].apply(lambda x: datetime.fromtimestamp(int(x)))
|
|
24
|
+
pd_candles['datetime'] = pd_candles['timestamp_ms'].apply(lambda x: datetime.fromtimestamp(int(x/1000)))
|
|
25
25
|
pd_candles['datetime'] = pd.to_datetime(pd_candles['datetime'])
|
|
26
26
|
pd_candles['datetime'] = pd_candles['datetime'].dt.tz_localize(None)
|
|
27
27
|
pd_candles['datetime_utc'] = pd_candles['timestamp_ms'].apply(
|
|
@@ -37,17 +37,17 @@ def timestamp_to_datetime_cols(pd_candles : pd.DataFrame):
|
|
|
37
37
|
pd_candles['dayofweek'] = pd_candles['datetime'].dt.dayofweek # dayofweek: Monday is 0 and Sunday is 6
|
|
38
38
|
|
|
39
39
|
pd_candles['week_of_month'] = pd_candles['timestamp_ms'].apply(
|
|
40
|
-
lambda x: timestamp_to_week_of_month(x)
|
|
40
|
+
lambda x: timestamp_to_week_of_month(int(x/1000))
|
|
41
41
|
)
|
|
42
42
|
|
|
43
43
|
pd_candles['apac_trading_hr'] = pd_candles['timestamp_ms'].apply(
|
|
44
|
-
lambda x: "APAC" in timestamp_to_active_trading_regions(x)
|
|
44
|
+
lambda x: "APAC" in timestamp_to_active_trading_regions(int(x/1000))
|
|
45
45
|
)
|
|
46
46
|
pd_candles['emea_trading_hr'] = pd_candles['timestamp_ms'].apply(
|
|
47
|
-
lambda x: "EMEA" in timestamp_to_active_trading_regions(x)
|
|
47
|
+
lambda x: "EMEA" in timestamp_to_active_trading_regions(int(x/1000))
|
|
48
48
|
)
|
|
49
49
|
pd_candles['amer_trading_hr'] = pd_candles['timestamp_ms'].apply(
|
|
50
|
-
lambda x: "AMER" in timestamp_to_active_trading_regions(x)
|
|
50
|
+
lambda x: "AMER" in timestamp_to_active_trading_regions(int(x/1000))
|
|
51
51
|
)
|
|
52
52
|
|
|
53
53
|
def timestamp_to_active_trading_regions(
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/candles_ta_provider.py
RENAMED
|
File without changes
|
|
File without changes
|
{siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/futu_candles_ta_to_csv.py
RENAMED
|
File without changes
|
{siglab_py-0.1.37 → siglab_py-0.1.50}/siglab_py/market_data_providers/orderbooks_provider.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|