Skip to content

Commit

Permalink
Revert Chinese market fees.
Browse files Browse the repository at this point in the history
Make this more configurable by providing a FeeStructure clas that can implement fee calculations.
  • Loading branch information
edtechre committed Dec 11, 2023
1 parent a7eb27e commit 60416a5
Show file tree
Hide file tree
Showing 2 changed files with 2 additions and 18 deletions.
1 change: 0 additions & 1 deletion src/pybroker/common.py
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,6 @@ class FeeMode(Enum):
"""

ORDER_PERCENT = "order_percent"
C_ORDER_PERCENT = "c_order_percent"
PER_ORDER = "per_order"
PER_SHARE = "per_share"

Expand Down
19 changes: 2 additions & 17 deletions src/pybroker/portfolio.py
Original file line number Diff line number Diff line change
Expand Up @@ -344,27 +344,12 @@ def __init__(
self._entry_id: int = 0
self._trade_id: int = 0

def _calculate_fees(
self,
fill_price: Decimal,
shares: Decimal,
type: Literal["buy", "sell"],
) -> Decimal:
def _calculate_fees(self, fill_price: Decimal, shares: Decimal) -> Decimal:
fees = Decimal()
if self._fee_mode is None or self._fee_amount is None:
return fees
if self._fee_mode == FeeMode.ORDER_PERCENT:
fees = self._fee_amount / Decimal(100) * fill_price * shares
elif self._fee_mode == FeeMode.C_ORDER_PERCENT:
if type == "buy":
fees = self._fee_amount / Decimal(100) * fill_price * shares
if fees < Decimal(5.0):
fees = Decimal(5.0)
else:
fees = self._fee_amount / Decimal(100) * fill_price * shares
if fees < Decimal(5.0):
fees = Decimal(5.0)
fees = fees + Decimal(0.0001) * fill_price * shares
elif self._fee_mode == FeeMode.PER_ORDER:
fees = self._fee_amount
elif self._fee_mode == FeeMode.PER_SHARE:
Expand Down Expand Up @@ -417,7 +402,7 @@ def _add_order(
shares: Decimal,
) -> Order:
self._order_id += 1
fees = self._calculate_fees(fill_price, shares, type)
fees = self._calculate_fees(fill_price, shares)
order = Order(
id=self._order_id,
date=date,
Expand Down

0 comments on commit 60416a5

Please sign in to comment.