-
Notifications
You must be signed in to change notification settings - Fork 21
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
There seems to be an issue with executing orders after they have been successfully executed twice before. #25
Comments
First and foremost, my friend, I appreciate your input on the subject of consecutive order placements. I've run into some trouble with Jupyter Notebook and the fix api, however, I plan to run some tests based on your insights. Please know that any PRs are highly encouraged. I apologize for my late response, I've been heavily involved in an AI project aimed at the financial market recently. I intend to perform the tests this week and aim to resolve some bugs. I've observed an issue with the FIX API concerning pauses between successive executions - this hasn't always been the case. I've also noted disparities across different brokers, particularly between demo and real accounts.
First and foremost, my friend, I appreciate your input on the subject of consecutive order placements. I've run into some trouble with Jupyter Notebook and the fix api, however, I plan to run some tests based on your insights. Please know that any PRs are highly encouraged. I apologize for my late response, I've been heavily involved in an AI project aimed at the financial market recently. I intend to perform the tests this week and aim to resolve some bugs. I've observed an issue with the FIX API concerning pauses between successive executions - this hasn't always been the case. I've also noted disparities across different brokers, particularly between demo and real accounts. |
Hi, I'd also like to mention that I have noticed the differences related to demo and real accounts. btw, Congratulations on your AI project, and I wish you the best! |
I have found the problem. When tag 35="AP" is received from the Broker, the parse_trade_message method searches in the binary data for the end of the FIX message, which in all cases is the checksum tag (tag 10)
However, the FIX message received contains various messages grouped into just one response, as shown in the following example:
If we carefully look into the received response, we can split it into 3 FIX messages:
Unfortunately, the regex is matching just the first one, resulting in parsing only the first message and causing the position list to contain only ONE position. This is why we can't close the other orders. Furthermore, related to this problem, the position list callback prevents the right execution and filling of the position list. (This is why subsequent orders cannot be closed after closing the first one). I have completed half of the fix, but I think I will need to refactor the callback for positions. |
|
Nice, work. How about an implementation of the same in rust, for latency's sake? |
I conducted some tests in Rust and observed no significant change in speed compared to Python. I believe Python is adequately serving our needs in this context. |
Hi,
After executing two consecutive trades using BUY and SELL Market types the next ones cannot be executed the log says it were executed but they aren't.
For example
i open a Buy order and then i try to close it using the method close_all() everything works fine. (I use this method because the close position by id doesn't work at all).
After that first successful execution if i try to open another one (in the same session) the new buy order executes correctly but if i try to use again the close_all method the buy order still persists in the market.
Another scenery is:
I can open many buy market orders but i cannot close them (using the close all method).
my implementations:
Buy ORDER
Close all:
Sometimes, the second try produces an unexpected infinite loop with a number of 16 digits.
I have some thoughts on what might be going on, but I need to test and debug those ideas when the market opens with a demo account.
Cheers
The text was updated successfully, but these errors were encountered: