-
Notifications
You must be signed in to change notification settings - Fork 570
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
[7][svk] Fractional trade dust left over sometimes #200
Comments
I can confirm. I watched $0.0003 execute ETH/bitUSD the other day on the chart and confirmed the trade history...yes that is 3/10,000 of one penny in value for that trade. Is this the 'sig fig' issue or else why is this dust reported? |
Absolutely, this is an incredibly important bug to squash for two reasons:
I don't know why these little amounts even exist or why they would trade so far out of range but if this is more than a GUI issue and actually an issue that is more deeply with Bitshares itself than it needs to be squashed immediately and therefore nothing would be necessary to change in the GUI. If Bitshares created this "fractional dust" on purpose to deal with something in the way it works then the GUI needs to understand it and to adjust the display properly. These wicks and bad balance calculations make bitshares look and feel poorly written which will prevent it from really succeeding. Let's fix it up and get to the next level here! |
For at least 20 minutes today ETH showed $400 price, dusted. |
I believe this is a top priority bug from a UX perspective. The crypto space is uncomfortable enough for newbs without their balances recalculating for no good reason. How about enforcing a minimum order size or even better, letting users set a filter to ignore insignificant trades in charts and trade history? @svk31 @bytemaster @wmbutler |
@happyconcepts No user would WANT to have those wicks or a poorly calculated balance so making it a filter is not the issue. The issue will be solved from finding how to define the dust in the code and how to clear it away in the GUI. |
Landry will you kindly explain to me why you feel the need to minimize each
and every one of my meager contributions to this repo? Is there no room for
my contribution because you don't understand the 0th element of arrays?
…On Jul 25, 2017 2:04 PM, "Landry Racoon" ***@***.***> wrote:
@happyconcepts <https://github.com/happyconcepts> No user would WANT to
have those wicks or a poorly calculated balance so making it a filter is
not the issue. The issue will be solved from finding how to define the dust
in the code and how to clear it away in the GUI.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#200 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ANfZLPiekH-6LylTr2nWv8fGtXLMIFPZks5sRlhygaJpZM4Of2SD>
.
|
What? I am saying this is a bug and there is no need to add an option to users to leave in the bug once it is solved. It may sound easy to you to simply add a filter but it is not that easy. The devs have to find out exactly how to isolate the trades in question and how to change to GUI to ignore them. It is not like they WANT to have long meaningless wicks and bad balances; they just haven't been able to fix the bug yet. I was not minimizing you contribution. I appreciate it and I am entirely on board with your desire to improve this program. |
Perhaps you would share where you see the value of my contribution instead
of useless platitudes about how much you love me at the end of your egoist
diatribes.
…On Jul 25, 2017 4:51 PM, "Landry Racoon" ***@***.***> wrote:
What? I am saying this is a bug and there is no need to add an option to
users to leave the bug in once it is solved.
It may sound easy to you to simply add a filter but it is not that easy.
The devs have to find out exactly how to isolate the trades in question and
how to change to GUI to ignore it. It is not like they WANT to have long
meaningless wicks and bad balances; they just haven't been able to fix the
bug yet.
I was not minimizing you contribution. I appreciate it and I am entirely
on board with your desire to improve this program.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#200 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/ANfZLBXrmv-F8acOeeKWpxzYp84AhbFQks5sRn95gaJpZM4Of2SD>
.
|
OMG, between the two of you I don't know which one ruins my Sunday more. |
@wmbutler Can you provide exact reproduction steps for this? |
I've observed it but cannot reliably reproduce. @svk31 says it's caused by the fees associated with a variable length of the memo field. I'll close it since it's my issue and I can't reproduce. |
No I do not think it's due to fees. The dust orders execute at a different price because Bitshares has no concept of price, only ratios of amounts to buy and sell. When there's only one satoshi left, the trade has to execute at a ratio (aka price) that is different from that originally defined for the order. The actual issue here is the existence of dust orders. I've spent countless hours on this issue and have apparently yet to figure out how to fix it, although I suspect it's now caused more by bots making incorrect orders than orders from the GUI. |
This phenomenon actually occurs in real securities markets, but at what seems to be a far lower frequency than I have observed on the Dex. When a stock trader finishes a large institutional order, for example, there is sometimes a "cleanup" print to the ticker tape for the last transaction(s) that is/are "away" from the market price. Usually market liquidity, meaning other buyers and sellers, are participating so that the price before the cleanup price again quickly becomes the market equilibrium...and the market . Afaik the "cleanup print" phenomenon is only because market rules require disclosure of all trades...but in its defense, price transparency is a good thing for credibility of any financial marketplace. So to not show a real trade, even if it's miniscule, is detrimental toward growing the user base imho. This. Dust. I will try to help solve it @svk31 |
I'm increasing the bounty to 4 hours. |
Thanks, I would like to work this with @svk31 -- can we push the delivery milestone out to Oct 1? I anticipate it is going to take some testing time especially. |
I'm bumping this to 7 hours but leaving it in the 170914 Sprint. I'll assign it to you but you will need to work out @svk31 cut based upon time spent. |
I'm not convinced this is fixeable in the GUI. In all the testing I've done in my last iteration on this issue (there have been many) I never managed to create any new dust orders after implementing the new market classes. It's possible the GUI still causes it in some cases but if so we need actual reproducible test cases, without them this issue is impossible to fix. And even though it may be fixed in the GUI, others might cause them elsewhere, especially bots making partial fills, and the real issue may actually lie with the bitshares-core code as discussed in these issues: bitshares/bitshares-core#342 and bitshares/bitshares-core#132 |
OK I decided to look at this after all, and was able to recreate the situation on the testnet. To reproduce:
Looking at how to fix it. |
Wow, you figured out how to reproduce, @svk31! I am always clicking and reclicking, changing, playing with the orderbook, so it was happening a lot to me. This is a very high priority bug imho because if fixed it will solve the wick problem and start to make the chart usable. Also, the jumping account value calculation which takes in the last market order to calculate will be fixed too. Looking forward to this bug squashing. |
@happyconcepts leaving this assigned to @svk31 only, FYI. |
@wmbutler thanks for the heads-up...the issue is in good hands :) |
Should be fixed with my latest commit but I've been wrong about this before, will close this issue but we should keep it in mind and reopen after the next release if it still happens. |
Winning!! |
Seems this wasn't actually fixed... guessing we are waiting to integrate trading view as discussed in issue #361 but will this fix the problem? Because if the same fractional trading dust data is being fed into trading view, I imagine the same problem with occur. Since posting in closed issues doesn't seem to work well, I am going to tag you guys. I can open an identical issue to this one but... it just seems silly when we can reopen this one... |
Why does it seem it wasn't fixed? We can only fix it in our GUI, bots and anyone using other interfaces are likely to create dust orders also, I've seen bots do it many times and there's nothing I can do about that. Tradingview charts will change nothing here, what needs to happen is for bitshares-core to filter out dust orders when creating market history. Ideally it would also just cancel any orders that only had dust left which cannot fill at the defined price, which is what's causing these issues in the first place.. |
Ok, there seem to be a few issues in the core github that touch on this like the ones you tagged above in #200 (comment) and maybe issue 287 too... Should I create an issue in the github for the core specifically about this problem? It would not be so technical as I am not as familiar with the code as you are but I could do it and reference this issue here then see what happens... I don't want to create a duplicate though. This is a very important issue as having a trading platform with usable charts is a big plus and regardless of if we are using react or tradingview, those wicks make things very difficult. You need to see REAL trading ranges to trade properly. Also, as I have mentioned, it causes the Account Value to jump around sometimes as it is taking the last trade to calculate and when the last trade is out of range, the Account Value goes out of range and becomes a very poor estimate. |
More discussion in bitshares/bitshares-core#449, and I proposed a fix in bitshares/bitshares-core#455. Please check. |
Actually there are two issues in this ticket:
|
When you click on a buy/sell order on an asset paired with BTS to fill it in the UI, and execute it, sometimes the UI places the order with an error of +/-0.0001 of the asset being traded. When this remaining order for 0.0001 subsequently fills, due to the small size of the order and the fees involved it winds up executing at a much higher/lower price than listed (ie. a sale at 2.2bitCNY coming to 2.5 after fees). In some instances, the chart on the UI will draw a wick extending to the substantially higher/lower price the small order wound up executing at. This makes the chart appear deceptive, particularly to new traders who have not been using the DEX long enough to see one of these orders execute, and observe the subsequent candle wick.
The text was updated successfully, but these errors were encountered: