tmm/logic/ema_chicken.py

67 lines
2.1 KiB
Python
Raw Permalink Normal View History

2022-07-15 10:17:55 +00:00
import asyncio
class EMA_Chicken:
def __init__(self, logger, pair, candle, lot, limit_rate):
self._logger = logger
self._pair = pair
self._candle = candle
self._remain = 0
self._total = 0
self._lot = lot
self._limit_rate = limit_rate
self._total = 0
asyncio.create_task(self._main())
async def _main(self):
self._logger.info("started")
while True:
await self._pair.ticker.wait()
if len(self._candle.values) == 0:
continue
price = self._pair.ticker.price
ema = self._candle.EMA(200)
if price > ema:
if self._remain < self._lot*3:
buy = await self._pair.buy_market(self._lot)
await asyncio.sleep(0.5)
await buy.update()
outgo = buy.price * self._lot
self._total -= outgo
self._remain += self._lot
2022-07-17 01:54:39 +00:00
self._logger.info(f"<BUY> {self._lot} / {outgo} ({self._remain} / {self._total})")
2022-07-15 10:17:55 +00:00
limit_price = buy.price*(1+self._limit_rate)
stop_price = buy.price*(1-self._limit_rate)
sell = await self._pair.sell_limit(self._lot, limit_price)
while True:
await asyncio.sleep(0.5)
await sell.update()
if sell.done:
amount = sell.amount - sell.remain
income = sell.price * amount
self._total += income
self._remain -= amount
if amount > 0:
2022-07-17 01:54:39 +00:00
self._logger.info(f"[WIN] <SELL> {amount} / {income} ({self._remain} / {self._total})")
2022-07-15 10:17:55 +00:00
break
if self._pair.ticker.price < stop_price:
await sell.cancel()
sell = await self._pair.sell_market(self._lot)
await asyncio.sleep(0.5)
await sell.update()
amount = sell.amount
income = sell.price * sell.amount
self._total += income
self._remain -= amount
if amount > 0:
2022-07-17 01:54:39 +00:00
self._logger.info(f"[LOSE] <SELL> {amount} / {income} ({self._remain} / {self._total})")
2022-07-15 10:17:55 +00:00
break