-
Notifications
You must be signed in to change notification settings - Fork 3.9k
Conversation
package-lock.json
Outdated
@@ -94,6 +94,15 @@ | |||
} | |||
} | |||
}, | |||
"JSONStream": { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do we need these changes?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No, any changes to the package-lock.json
are based on local package preferences, and aren't required for this PR, I'll remove that.
plugins/trader/trade.js
Outdated
@@ -0,0 +1,293 @@ | |||
/* | |||
@askmike |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
better to link to the discussion than copy snippets of it in a comment :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed, will update.
// the asset, if so BUY and keep track of the order | ||
// (amount is in asset quantity) | ||
buy(amount, price) { | ||
let minimum = 0; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
pretty sure we had a minimum, right?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, that code is just directly pasted from the previous implementation, looks like the minimum is defined later on line 133
before the callback is executed.
plugins/trader/portfolioManager.js
Outdated
// If unfilled, cancel and replace order with adjusted price | ||
let cancelDelay = this.conf.orderUpdateDelay || 1; | ||
setTimeout(this.checkOrder, util.minToMs(cancelDelay)); | ||
return this.currentTrade = new Trade(this,{action: what}) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If we want to stick to OO: can you not pass the parent (portfolioManager) into the child (trade), these circular references are tightly coupled.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, it's not ideal, let's fix this.
Currently there are multiple references to the manager inside the trade class, which would call for some restructuring. This is what we could do:
- A new exchange object could be created inside the Trade class so it's not referencing it in the Manager, thus removing references to
manager.exchange
- We can pass in the current pair currency/asset handles into the Trade class on creation, and remove
manager.asset
andmanager.currency
- Currently the following methods are being called by the Trade class, how do you suggest we handle this?
this.manager.setTicker
this.manager.setPortfolio
this.manager.setFee
this.manager.getMinimum
this.manager.convertPortfolio
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this.manager.convertPortfolio
This is currently only needed for emitting events upstream, the trade class doesn't need it.
Some other functions won't be needed anymore by the portfolioManager, like setFee and setTicker (we will need this one later again, for the portfolioValueChange event for example). All the other functions will be used differently anyway, so I propose the portfolioManager passes the exchange (this.exchange
) to the tradeclass which reimplements what it needs, we can also drop in the portfolioManager what we don't need. What do you think?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@askmike OK that makes sense, yes let's keep a single Exchange instance, and move the methods into the Trade class. I'll make that happen, test it and update this PR.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See few comments, also: does the ES6 class syntax work nodev6? If it doesn't there is a node update process we need to go through.
Yes, Classes should work since Node |
what's the current status with this branch? is it usable or are there still changes to be made? |
Gekko should work for Gekko v6.0, we can upgrade the minimum but as explained above this is a different process. I do want to move to use classes more so I'll look into any possible negative effects of requiring a higher version of nodejs. |
@askmike Yes, I'm open to go through a Node upgrade process whatever is required, I think it's important to be progressive with adopting new standards. |
@askmike I made the modifications that we discussed earlier in the code comments. Since the "Portfolio" object and associated methods needed to be accessed by both the Trade class and the Portfolio Manager class, I broke it out into a "Portfolio" class / object which has a shared reference between both classes, which contains the portfolio data and ticker. I tested this extensively in high frequency / high tick rate and high position reversal conditions on the live market and it works as expected. This is not ready to merge yet until the logging and syntax is cleaned up, I'd like to make it more consistent. I'm curious to get your feedback on the last commit. After this, the next thing I'd like to develop on this is a proper data model for Let me know your thoughts on this last commit, it's ready to be live tested. |
I am looking forward to this! Thanks everyone involved. |
@askmike Also what is required to conduct a Node 6.5+ upgrade so we can get ES6 support? While we are at it why not update to Node 8? I've been running Node 8 on Windows and Linux without any issues thus far. |
@ansonphong node8 is diffcult to install on some raspberry pi versions. So you loose a little flexibility if you go to node 8 directly. Plus node 8 does not bring that much to the game to be worth making it a requirement. |
@aapsoftware How about Node V6.5, that supports ES6, is that manageable on Raspi? |
exchange:this.exchange, | ||
currency: this.conf.currency, | ||
asset: this.conf.asset, | ||
portfolio: this.portfolio, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I do not like all of these property values passed in, ideally it's just action
, currency
, asset
, and then an amount
which could have an undefined value which would then default to the system settings for currency allowance, keep asset, etc.
@askmike You know the architecture best, is there an currently established way by which we could store references to globally accessible objects / dependencies without resorting to a singleton?
@askmike Can you have a look at this when you have some time? I'd like to make a decisive move on this PR, as a lot of future work I'd like to do builds on this. Thanks! |
Apologies for the delay. I am testing this now, If I don't find problems I
will merge it today.
…On Fri, 30 Mar 2018, 10:04 phong, ***@***.***> wrote:
@askmike <https://github.com/askmike> Can you have a look at this when
you have some time? I'd like to make a decisive move on this PR, as a lot
of future work I'd like to do builds on this. Thanks!
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#1968 (comment)>, or mute
the thread
<https://github.com/notifications/unsubscribe-auth/AA7MD7rH8J3kkCMFvnpo1iL5rZqqVNc7ks5tjaDLgaJpZM4SR6Y->
.
|
@ansonphong I'm interested in moving this forward and have availability, please let me know how to work with you in getting there faster... @askmike I'm also eagerly awaiting this :) |
Great thanks, @jamespfarrell you are welcome to test this PR, I'm only 99% confident that it works as expected, having others help testing is always helpful. @askmike Check my comments above, I can do a final pass at it before merging. |
@ansonphong interesting |
I made another push which basically just cleans up some of the debugging language and the comments a little bit, it should be ready to merge. I'm not content with the solution for passing the That said, this PR simply breaks out the existing functionality into separate classes, and does not introduce any new functionality. The next work will require refactoring the methods to allow for an architecture which will allow for sub-classes of the Trade class which can carry out different trade strategies. For instance, alternate strategies could include layering multiple orders, placing market orders, etc, and pave the way for more sophisticated systems in Gekko which could allow for position sizing, etc. The refactoring can happen on another PR. The very next step I'd like to take with it is to build an |
If I understand you correctly, with this refactoring a Portfolio refers to an exchange portfolio, rather and an entire portfolio across many exchanges? Also, if I understand this approach correctly you we will be able to apply many strategies on the market, but since this is operating through plugins on the GekkoStream, this will still only be able to act on 1 market at a time? @ansonphong @askmike I would love to test the PR but can't get a copy of it besides making the change manually. I have done a lot of googling and tried a lot of commands, but can't seem to get a copy... Can you help? I'm super keen to test and further this issue... I have tried: git fetch origin pull/1968/ansonphong:trade-class I have also run through this with no joyl. and few other things... @ansonphong are you working on a fork? |
@jamespfarrell You can easily pull off my fork to test: In your local developent Gekko, just go 👍 Still will only be on one market at a time, though you will be able to run multiple instances. |
This is long overdue, again apologies for the delay. This PR is perfect in that it only moves around code but doesn't change behaviour / introduces new concepts. Love to work on upgrades and will reply to your latest comment @ansonphong asap! |
Before this can land in stable we do need to upgrade the minimal node version (as stated before), but as part of #1850 this will be necessary anyway. I will focus on that. |
@askmike Sounds good, happy to get this merged. Are you open to eliminating all semicolons on line endings for ES6 code? |
|
What do semicolons have to do with ES6? Did anything change? As far as I know they were optional and they still are optional. Most styleguides I know recommend using them though. |
* subtract candle length from start time to calculate isPremature * Move startTimeMinusCandleSize inside realtime if check * return the indicator after adding it * develop trade class * make fixes after live market test * line spacing * rollback package-lock.json to develop branch * link to discussion: * move methods from portfolio manager into trade class and new portfolio class * cleanup logging, comments
* fix typo * fix server api changes * fix for Introduce Trade Class (#1968) breaking events emitter
What kind of change does this PR introduce?
A new class that is responsible for doing a single trade.
Related to discussion in Issue A new class that is responsible for doing a single trade... #1942
What is the current behavior?
Currently all the trade and order functionality is mashed into the portfolio manager, making it impossible to deploy different trade and order execution strategies, as everything is hard-coded to one specific type of trade execution which is a single limit order for the full balance amount right across from the spread.
What is the new behavior (if this is a feature change)?
This PR strictly breaks out the trade specific functionality (as-is) into a separate Trade class, with minimal modification and no refactoring.
Other information:
This is an initial proposal for the Trade class. I have tested it on the live market and it works as expected without any errors so far. I'm curious to see others kick the tires and try to shoot holes in it and see how it works in different circumstances, and see if I missed anything.
This PR is far from ideal as a final implementation, and is part of an incremental series of PRs which will see a total refactor of the
Portfolio Manager
, thisTrade
class, and the introduction of a more robustOrder
model. Refer to the Issue #1942 for further discussion.