📜 [專欄新文章] Uniswap v3 Features Explained in Depth
✍️ 田少谷 Shao
📥 歡迎投稿: https://medium.com/taipei-ethereum-meetup #徵技術分享文 #使用心得 #教學文 #medium
Once again the game-changing DEX 🦄 👑
Image source: https://uniswap.org/blog/uniswap-v3/
Outline
0. Intro1. Uniswap & AMM recap2. Ticks 3. Concentrated liquidity4. Range orders: reversible limit orders5. Impacts of v36. Conclusion
0. Intro
The announcement of Uniswap v3 is no doubt one of the most exciting news in the DeFi place recently 🔥🔥🔥
While most have talked about the impact v3 can potentially bring on the market, seldom explain the delicate implementation techniques to realize all those amazing features, such as concentrated liquidity, limit-order-like range orders, etc.
Since I’ve covered Uniswap v1 & v2 (if you happen to know Mandarin, here are v1 & v2), there’s no reason for me to not cover v3 as well ✅
Thus, this article aims to guide readers through Uniswap v3, based on their official whitepaper and examples made on the announcement page. However, one needs not to be an engineer, as not many codes are involved, nor a math major, as the math involved is definitely taught in your high school, to fully understand the following content 😊😊😊
If you really make it through but still don’t get shxt, feedbacks are welcomed! 🙏
There should be another article focusing on the codebase, so stay tuned and let’s get started with some background noise!
1. Uniswap & AMM recap
Before diving in, we have to first recap the uniqueness of Uniswap and compare it to traditional order book exchanges.
Uniswap v1 & v2 are a kind of AMMs (automated market marker) that follow the constant product equation x * y = k, with x & y stand for the amount of two tokens X and Y in a pool and k as a constant.
Comparing to order book exchanges, AMMs, such as the previous versions of Uniswap, offer quite a distinct user experience:
AMMs have pricing functions that offer the price for the two tokens, which make their users always price takers, while users of order book exchanges can be both makers or takers.
Uniswap as well as most AMMs have infinite liquidity¹, while order book exchanges don’t. The liquidity of Uniswap v1 & v2 is provided throughout the price range [0,∞]².
Uniswap as well as most AMMs have price slippage³ and it’s due to the pricing function, while there isn’t always price slippage on order book exchanges as long as an order is fulfilled within one tick.
In an order book, each price (whether in green or red) is a tick. Image source: https://ftx.com/trade/BTC-PERP
¹ though the price gets worse over time; AMM of constant sum such as mStable does not have infinite liquidity
² the range is in fact [-∞,∞], while a price in most cases won’t be negative
³ AMM of constant sum does not have price slippage
2. Tick
The whole innovation of Uniswap v3 starts from ticks.
For those unfamiliar with what is a tick:
Source: https://www.investopedia.com/terms/t/tick.asp
By slicing the price range [0,∞] into numerous granular ticks, trading on v3 is highly similar to trading on order book exchanges, with only three differences:
The price range of each tick is predefined by the system instead of being proposed by users.
Trades that happen within a tick still follows the pricing function of the AMM, while the equation has to be updated once the price crosses the tick.
Orders can be executed with any price within the price range, instead of being fulfilled at the same one price on order book exchanges.
With the tick design, Uniswap v3 possesses most of the merits of both AMM and an order book exchange! 💯💯💯
So, how is the price range of a tick decided?
This question is actually somewhat related to the tick explanation above: the minimum tick size for stocks trading above 1$ is one cent.
The underlying meaning of a tick size traditionally being one cent is that one cent (1% of 1$) is the basis point of price changes between ticks, ex: 1.02 — 1.01 = 0.1.
Uniswap v3 employs a similar idea: compared to the previous/next price, the price change should always be 0.01% = 1 basis point.
However, notice the difference is that in the traditional basis point, the price change is defined with subtraction, while here in Uniswap it’s division.
This is how price ranges of ticks are decided⁴:
Image source: https://uniswap.org/whitepaper-v3.pdf
With the above equation, the tick/price range can be recorded in the index form [i, i+1], instead of some crazy numbers such as 1.0001¹⁰⁰ = 1.0100496621.
As each price is the multiplication of 1.0001 of the previous price, the price change is always 1.0001 — 1 = 0.0001 = 0.01%.
For example, when i=1, p(1) = 1.0001; when i=2, p(2) = 1.00020001.
p(2) / p(1) = 1.00020001 / 1.0001 = 1.0001
See the connection between the traditional basis point 1 cent (=1% of 1$) and Uniswap v3’s basis point 0.01%?
Image source: https://tenor.com/view/coin-master-cool-gif-19748052
But sir, are prices really granular enough? There are many shitcoins with prices less than 0.000001$. Will such prices be covered as well?
Price range: max & min
To know if an extremely small price is covered or not, we have to figure out the max & min price range of v3 by looking into the spec: there is a int24 tick state variable in UniswapV3Pool.sol.
Image source: https://uniswap.org/whitepaper-v3.pdf
The reason for a signed integer int instead of an uint is that negative power represents prices less than 1 but greater than 0.
24 bits can cover the range between 1.0001 ^ (2²³ — 1) and 1.0001 ^ -(2)²³. Even Google cannot calculate such numbers, so allow me to offer smaller values to have a rough idea of the whole price range:
1.0001 ^ (2¹⁸) = 242,214,459,604.341
1.0001 ^ -(2¹⁷) = 0.000002031888943
I think it’s safe to say that with a int24 the range can cover > 99.99% of the prices of all assets in the universe 👌
⁴ For implementation concern, however, a square root is added to both sides of the equation.
How about finding out which tick does a price belong to?
Tick index from price
The answer to this question is rather easy, as we know that p(i) = 1.0001^i, simply takes a log with base 1.0001 on both sides of the equation⁴:
Image source: https://www.codecogs.com/latex/eqneditor.php
Let’s try this out, say we wanna find out the tick index of 1000000.
Image source: https://ncalculators.com/number-conversion/log-logarithm-calculator.htm
Now, 1.0001¹³⁸¹⁶² = 999,998.678087146. Voila!
⁵ This formula is also slightly modified to fit the real implementation usage.
3. Concentrated liquidity
Now that we know how ticks and price ranges are decided, let’s talk about how orders are executed in a tick, what is concentrated liquidity and how it enables v3 to compete with stablecoin-specialized DEXs (decentralized exchange), such as Curve, by improving the capital efficiency.
Concentrated liquidity means LPs (liquidity providers) can provide liquidity to any price range/tick at their wish, which causes the liquidity to be imbalanced in ticks.
As each tick has a different liquidity depth, the corresponding pricing function x * y = k also won’t be the same!
Each tick has its own liquidity depth. Image source: https://uniswap.org/blog/uniswap-v3/
Mmm… examples are always helpful for abstract descriptions 😂
Say the original pricing function is 100(x) * 1000(y) = 100000(k), with the price of X token 1000 / 100 = 10 and we’re now in the price range [9.08, 11.08].
If the liquidity of the price range [11.08, 13.08] is the same as [9.08, 11.08], we don’t have to modify the pricing function if the price goes from 10 to 11.08, which is the boundary between two ticks.
The price of X is 1052.63 / 95 = 11.08 when the equation is 1052.63 * 95 = 100000.
However, if the liquidity of the price range [11.08, 13.08] is two times that of the current range [9.08, 11.08], balances of x and y should be doubled, which makes the equation become 2105.26 * 220 = 400000, which is (1052.63 * 2) * (110 * 2) = (100000 * 2 * 2).
We can observe the following two points from the above example:
Trades always follow the pricing function x * y = k, while once the price crosses the current price range/tick, the liquidity/equation has to be updated.
√(x * y) = √k = L is how we represent the liquidity, as I say the liquidity of x * y = 400000 is two times the liquidity of x * y = 100000, as √(400000 / 100000) = 2.
What’s more, compared to liquidity on v1 & v2 is always spread across [0,∞], liquidity on v3 can be concentrated within certain price ranges and thus results in higher capital efficiency from traders’ swapping fees!
Let’s say if I provide liquidity in the range [1200, 2800], the capital efficiency will then be 4.24x higher than v2 with the range [0,∞] 😮😮😮 There’s a capital efficiency comparison calculator, make sure to try it out!
Image source: https://uniswap.org/blog/uniswap-v3/
It’s worth noticing that the concept of concentrated liquidity was proposed and already implemented by Kyper, prior to Uniswap, which is called Automated Price Reserve in their case.⁵
⁶ Thanks to Yenwen Feng for the information.
4. Range orders: reversible limit orders
As explained in the above section, LPs of v3 can provide liquidity to any price range/tick at their wish. Depending on the current price and the targeted price range, there are three scenarios:
current price < the targeted price range
current price > the targeted price range
current price belongs to the targeted price range
The first two scenarios are called range orders. They have unique characteristics and are essentially fee-earning reversible limit orders, which will be explained later.
The last case is the exact same liquidity providing mechanism as the previous versions: LPs provide liquidity in both tokens of the same value (= amount * price).
There’s also an identical product to the case: grid trading, a very powerful investment tool for a time of consolidation. Dunno what’s grid trading? Check out Binance’s explanation on this, as this topic won’t be covered!
In fact, LPs of Uniswap v1 & v2 are grid trading with a range of [0,∞] and the entry price as the baseline.
Range orders
To understand range orders, we’d have to first revisit how price is discovered on Uniswap with the equation x * y = k, for x & y stand for the amount of two tokens X and Y and k as a constant.
The price of X compared to Y is y / x, which means how many Y one can get for 1 unit of X, and vice versa the price of Y compared to X is x / y.
For the price of X to go up, y has to increase and x decrease.
With this pricing mechanism in mind, it’s example time!
Say an LP plans to place liquidity in the price range [15.625, 17.313], higher than the current price of X 10, when 100(x) * 1000(y) = 100000(k).
The price of X is 1250 / 80 = 15.625 when the equation is 80 * 1250 = 100000.
The price of X is 1315.789 / 76 = 17.313 when the equation is 76 * 1315.789 = 100000.
If now the price of X reaches 15.625, the only way for the price of X to go even higher is to further increase y and decrease x, which means exchanging a certain amount of X for Y.
Thus, to provide liquidity in the range [15.625, 17.313], an LP needs only to prepare 80 — 76 = 4 of X. If the price exceeds 17.313, all 4 X of the LP is swapped into 1315.789 — 1250 = 65.798 Y, and then the LP has nothing more to do with the pool, as his/her liquidity is drained.
What if the price stays in the range? It’s exactly what LPs would love to see, as they can earn swapping fees for all transactions in the range! Also, the balance of X will swing between [76, 80] and the balance of Y between [1250, 1315.789].
This might not be obvious, but the example above shows an interesting insight: if the liquidity of one token is provided, only when the token becomes more valuable will it be exchanged for the less valuable one.
…wut? 🤔
Remember that if 4 X is provided within [15.625, 17.313], only when the price of X goes up from 15.625 to 17.313 is 4 X gradually swapped into Y, the less valuable one!
What if the price of X drops back immediately after reaching 17.313? As X becomes less valuable, others are going to exchange Y for X.
The below image illustrates the scenario of DAI/USDC pair with a price range of [1.001, 1.002] well: the pool is always composed entirely of one token on both sides of the tick, while in the middle 1.001499⁶ is of both tokens.
Image source: https://uniswap.org/blog/uniswap-v3/
Similarly, to provide liquidity in a price range < current price, an LP has to prepare a certain amount of Y for others to exchange Y for X within the range.
To wrap up such an interesting feature, we know that:
Only one token is required for range orders.
Only when the current price is within the range of the range order can LP earn trading fees. This is the main reason why most people believe LPs of v3 have to monitor the price more actively to maximize their income, which also means that LPs of v3 have become arbitrageurs 🤯
I will be discussing more the impacts of v3 in 5. Impacts of v3.
⁷ 1.001499988 = √(1.0001 * 1.0002) is the geometric mean of 1.0001 and 1.0002. The implication is that the geometric mean of two prices is the average execution price within the range of the two prices.
Reversible limit orders
As the example in the last section demonstrates, if there is 4 X in range [15.625, 17.313], the 4 X will be completely converted into 65.798 Y when the price goes over 17.313.
We all know that a price can stay in a wide range such as [10, 11] for quite some time, while it’s unlikely so in a narrow range such as [15.625, 15.626].
Thus, if an LP provides liquidity in [15.625, 15.626], we can expect that once the price of X goes over 15.625 and immediately also 15.626, and does not drop back, all X are then forever converted into Y.
The concept of having a targeted price and the order will be executed after the price is crossed is exactly the concept of limit orders! The only difference is that if the range of a range order is not narrow enough, it’s highly possible that the conversion of tokens will be reverted once the price falls back to the range.
As price ranges follow the equation p(i) = 1.0001 ^ i, the range can be quite narrow and a range order can thus effectively serve as a limit order:
When i = 27490, 1.0001²⁷⁴⁹⁰ = 15.6248.⁸
When i = 27491, 1.0001²⁷⁴⁹¹ = 15.6264.⁸
A range of 0.0016 is not THAT narrow but can certainly satisfy most limit order use cases!
⁸ As mentioned previously in note #4, there is a square root in the equation of the price and index, thus the numbers here are for explantion only.
5. Impacts of v3
Higher capital efficiency, LPs become arbitrageurs… as v3 has made tons of radical changes, I’d like to summarize my personal takes of the impacts of v3:
Higher capital efficiency makes one of the most frequently considered indices in DeFi: TVL, total value locked, becomes less meaningful, as 1$ on Uniswap v3 might have the same effect as 100$ or even 2000$ on v2.
The ease of spot exchanging between spot exchanges used to be a huge advantage of spot markets over derivative markets. As LPs will take up the role of arbitrageurs and arbitraging is more likely to happen on v3 itself other than between DEXs, this gap is narrowed … to what extent? No idea though.
LP strategies and the aggregation of NFT of Uniswap v3 liquidity token are becoming the blue ocean for new DeFi startups: see Visor and Lixir. In fact, this might be the turning point for both DeFi and NFT: the two main reasons of blockchain going mainstream now come to the alignment of interest: solving the $$ problem 😏😏😏
In the right venue, which means a place where transaction fees are low enough, such as Optimism, we might see Algo trading firms coming in to share the market of designing LP strategies on Uniswap v3, as I believe Algo trading is way stronger than on-chain strategies or DAO voting to add liquidity that sort of thing.
After reading this article by Parsec.finance: The Dex to Rule Them All, I cannot help but wonder: maybe there is going to be centralized crypto exchanges adopting v3’s approach. The reason is that since orders of LPs in the same tick are executed pro-rata, the endless front-running speeding-competition issue in the Algo trading world, to some degree, is… solved? 🤔
Anyway, personal opinions can be biased and seriously wrong 🙈 I’m merely throwing out a sprat to catch a whale. Having a different voice? Leave your comment down below!
6. Conclusion
That was kinda tough, isn’t it? Glad you make it through here 🥂🥂🥂
There are actually many more details and also a huge section of Oracle yet to be covered. However, since this article is more about features and targeting normal DeFi users, I’ll leave those to the next one; hope there is one 😅
If you have any doubt or find any mistake, please feel free to reach out to me and I’d try to reply AFAP!
Stay tuned and in the meantime let’s wait and see how Uniswap v3 is again pioneering the innovation of DeFi 🌟
Uniswap v3 Features Explained in Depth was originally published in Taipei Ethereum Meetup on Medium, where people are continuing the conversation by highlighting and responding to this story.
👏 歡迎轉載分享鼓掌
同時也有3部Youtube影片,追蹤數超過361萬的網紅Dan Lok,也在其Youtube影片中提到,Sick And Tired Of Being Stuck In The Entrepreneurial Doom Loop And Not Getting To Where You Want In Life? Click Here And Discover Dan’s Best-Kept Secr...
「personal blog example」的推薦目錄:
- 關於personal blog example 在 Taipei Ethereum Meetup Facebook 的最佳解答
- 關於personal blog example 在 AppWorks Facebook 的最讚貼文
- 關於personal blog example 在 SF Artography Facebook 的最佳貼文
- 關於personal blog example 在 Dan Lok Youtube 的最佳解答
- 關於personal blog example 在 Melody Tam Youtube 的最讚貼文
- 關於personal blog example 在 SiennyLoves Drawing Youtube 的最讚貼文
- 關於personal blog example 在 20 Inspiring and Creative Personal Blog Web Designs 的評價
- 關於personal blog example 在 Wordpress Blog with Elementor Full Tutorial for 2020 - YouTube 的評價
- 關於personal blog example 在 Charca/astro-blog-template - GitHub 的評價
- 關於personal blog example 在 金老ㄕ的教學日誌 - Facebook 的評價
personal blog example 在 AppWorks Facebook 的最讚貼文
Interview with A Founder: Conor McLaughlin (Co-founder of 99.co)
By David Wu (AppWorks Associate)
Conor McLaughlin was previously the Co-founder and CTO of 99.co, the real estate marketplace in Singapore and Indonesia. He spent six and a half years at the startup, whose backers include Sequoia Capital, 500 Startups, and Facebook co-founder Eduardo Saverin, helping to grow it into a $100 million company. As a member of AppWorks Accelerator #21, he is currently working on his next big project, a yet-to-be-named language learning startup.
【What advice do you have for first-time founders?】
First, you need to decide: do I want to run a sprint or a marathon? For a sprint, you may be open to acquisition from the beginning, delay non-startup aspects of your life, give yourself two years where you drop everything to test an idea, choose to raise more money earlier on and thus be more diluted, or do anything else that implies a shorter time horizon. Typically 1-5 years - this can lead to a major boon in a short period of time if executed well. If you decide you are in the sprinting business, you will most likely be pushed toward binary outcomes because of how many investors and employees you have on your cap table. As a first-time founder, you need to be clear with yourself on what you are willing to put on the line. As Reid Hoffman says, it’s like jumping off a cliff and building a plane on the way down… hopefully you build a plane in time.
If you are running a marathon, you are deciding that your competitive advantage is consistency over intensity. You are in this for 10, 15 years. With this time horizon, you will realize you need ways to metabolize stress and maintain emotional, spiritual, and mental health. You need to maintain relationships with friends, family, and romantic partners. When you are looking at this 10 year period, you realize the people around you can only put up with so much. Unfortunately, while work is something people can generally bounce back from, there are many things in life where you cannot - an example is your relationship with your partner. If you’re going to run a marathon, you need to be clear with yourself about what time you have for other aspects of your life and what time you have for your company. Eventually you need to learn what the right speed is where you can run as long as possible. It’s amazing how often it is that those people that keep going, assuming you have chosen the right problem to solve, eventually find daylight. Part of that is just lasting long enough.
Second, you need to revisit and continually ask yourself: should I still be running a sprint or a marathon? Circumstances change. Maybe you sprinted for the first two years to secure interesting results and funding; now it's time to transition to a marathon and clean up the life debt a bit. Or inversely, maybe you're finally leaving the trough of sorrow and it's time to sprint for a bit. Most founders will be in a long distance race with periodic sprinting. From my observation, founders most often stop because of two reasons: They either A) run out of money or B) run out of energy. There’s plenty of advice out there for scenario A (hint: don’t). But in my experience, scenario B is far more pernicious and dangerous to would-be successful founders. If you are in a marathon but fail to pace yourself and run it like one long sprint, you are unlikely to make it to the end.
Much founder advice speaks to this: Don’t let your startup make you fat. Exercise 5-10% of the time. Pick up a hobby outside of your startup. Go home for holidays. All of it leads back to one thing: You need to take care of yourself. Because injury will be far worse for your progress than being a little slower. “Slow is smooth, smooth is fast”, as the US Navy Seals say. This is surprisingly difficult advice for intrinsically motivated founders to follow, because in the event of failure, it makes them vulnerable to the thought, “Well, you didn’t work hard enough.” But for those that already have the hustle, your job is to avoid the moment of epiphany where you look in the mirror and think, “This isn’t worth it.”
All founders will have to sacrifice some things. The point is to not sacrifice everything. It will make you more resilient. Not less. It will give you the space to see situations more objectively and make better decisions. And most importantly, it will let you love what you do because it will remind you that the work isn’t just in service of yourself, it’s in the service of others. I do not think you can judge hard work over a day, or even a year, but I do think you can judge hard work over 5-10 years. Hard work is not just about the next 1-2 months. There will be times when you need to run as fast as possible, but if that is happening all the time you are probably not being smart about the situation. So don’t hurt yourself, be consistent, keep disciplined, and keep going.
Lastly, focus on your metaskills. Public speaking, reading, writing - skills applied in every aspect of your life. Generally what they reflect is learning how to think better. As a founder you need to think about - how can I think more clearly, be more creative, rigorous, analytical? As Warren Buffett and others have said: I have never seen a successful person that did not read as often as they could. Actual books and long form scare a lot of people. That’s your competitive advantage. Read blog posts from smart people, follow smart people on Twitter, listen to podcasts. Always be focused on how you can develop yourself to think better. Fostering the habit of improving your thinking will foster discipline in yourself. And discipline will let you turn that rigorous thinking into action.
【I imagine running the “race” has been especially tough this year. How have you gotten through 2020?】
I have leaned on routine and community. I’ve spent a lot of time trying to foster discipline in myself. I make my bed every morning, meditate every morning, make sure that I go to the gym 3-4 times a week. There’s so much uncertainty in both the world and the entrepreneurial space. Keeping certain things consistent gives me a spine to my life that I can fall back on. If I’m not feeling well, my discipline takes over and I’ll go to the gym. That helps me relieve stress - falling back to routine and having some mainstays of consistency and structure.
And community - it’s been the big mental health zeitgeist of this year. Everyone is recognizing that without the people around us, our mental health diminishes. Joining AppWorks was very intentional so I could surround myself with like-minded people who could question me, hold me accountable, and inspire me. And also just forming personal connections where I felt that I was still taking care of my mental health by connecting with others. Being a founder is an incredibly lonely journey. In the early days, there’s not a lot of people around. Later, when you do hire lots of people, you need to be the boss, the leader - for certain things, you can’t tell the employees everything, and even if you do, there will always be a bit of distance. You need people to relate to - people want to be seen for who they are, and appreciated for what they give. When you are a founder, sometimes it’s hard to feel that you are seen. So I intentionally put myself in situations where I can be inspired, be held accountable, and more importantly connect with others, and feel that I’m not alone. And that me and my co-founders are part of a communal journey with those around us.
【When you talk about how to run the race, I get the sense that you’re drawing from previous experiences and, perhaps, mistakes. What are the mistakes you’ve made in your founder journey and the takeaways?】
I think you could take a calendar, point to a random week, and we could list out all the mistakes from that week (laughs). I do subscribe to Steve Jobs’ philosophy: mistakes will happen, but mistakes happening means we are making decisions. Not making decisions is perhaps the biggest mistake. It’s often the reason for frustration, loss of speed, loss of momentum - so many of the issues you encounter in startups. Not making enough mistakes is probably the #1 mistake that I’ve made.
Second, going back to my advice to first-time founders, is not understanding what game I’m playing. Not understanding that all the money in the world is not going to be worth it if your spouse or partner decides to leave you because you have relegated them to a second-class citizen in your life. I think I forgot that at points. There is more to life than just the company.
Third, be careful about who you choose to work with. At minimum, if you’re doing a standard 8-9 hours at the office five times a week, that’s a lot of time with those people. You want to like the people that you work with - you want to know they’re high integrity, you want to respect their values, and you want to have common values. Choosing the right people that give you energy rather than take it away just makes running the marathon so much easier.
【We welcome all AI, Blockchain, or Southeast Asia founders to join AppWorks Accelerator: https://bit.ly/3r4lLR8 】
personal blog example 在 SF Artography Facebook 的最佳貼文
Hey guys! Do you want to earn extra money with your skills?🤩 Are you looking for opportunity to find job and generate income for your services?
You can now do so with AskAlan the Malaysia’s Latest and Largest Service-Bidding Platform in Kuala Lumpur. There are many opportunities for example Content Writer, Photo/Videographer, Personal Chef, Personal Shopper, Mechanic, Pet Car services, lessons and training services, professional service and many more!💪
💫Sign up AskAlan PROvider apps and stand a chance to win an iPhone 12 pro max and prizes up to RM10,000!🔥Also get extra RM8 reward credit using my referral code "sf_artography" Sign up now at https://7nzs6.app.link/sf_artography
For more information about the contest, visit https://www.askalan.com.my/blog/askalan4iphone-contest
#askalan4iphone #askalan #sfartography #rainbowpegasus #askalan
personal blog example 在 Dan Lok Youtube 的最佳解答
Sick And Tired Of Being Stuck In The Entrepreneurial Doom Loop And Not Getting To Where You Want In Life? Click Here And Discover Dan’s Best-Kept Secrets To Ending The Doom Loop In His New Book, Unlock It: http://doomloop.danlok.link
One of the greatest struggles today is getting stuck in the doom loop. So how can you escape that and get to the next level in business and your personal life? Sit down with Dan and Brian Scudamore, the founder of 1-800-GOT-JUNK?, as they share the doom loop definition and a powerful strategy to ending the doom loop and achieving the goals you have.
? SUBSCRIBE TO DAN'S YOUTUBE CHANNEL NOW ?
https://www.youtube.com/danlok?sub_confirmation=1
Check out these Top Trending Playlists -
1.) Boss In The Bentley - https://www.youtube.com/playlist?list=PLEmTTOfet46OWsrbWGPnPW8mvDtjge_6-
2.) Sales Tips That Get People To Buy - https://www.youtube.com/watch?v=E6Csz_hvXzw&list=PLEmTTOfet46PvAsPpWByNgUWZ5dLJd_I4
3.) Dan Lok’s Best Secrets - https://www.youtube.com/watch?v=FZNmFJUuTRs&list=PLEmTTOfet46N3NIYsBQ9wku8UBNhtT9QQ
Not long ago, Dan Lok was just a poor immigrant boy. He had nothing but a strong desire to get out of debt and make enough to provide for his single mom. With this strong desire, Dan quit his job as a grocery bagger. He dropped out of college. And he became an entrepreneur.
After 13 failed businesses, Dan finally became a self-made millionaire at age 27 and multi-millionaire by age 30.
Fast forward to today, Dan is now an official Forbes Book author with over 13 internationally best-selling books. He’s the founder and chairman of several multimillion dollar businesses. And outside of his business success, he is one of the most-watched, most quoted and most followed educators of our time. In total, his videos have been watched over 100-million times across his social media platforms. His emails are read by over 2,000,000 people every month.
If you want the no b.s. way to master your financial destiny, then learn from Dan. Subscribe to his channel now.
★☆★ CONNECT WITH DAN ON SOCIAL MEDIA ★☆★
YouTube: http://youtube.danlok.link
Dan Lok Blog: http://blog.danlok.link
Facebook: http://facebook.danlok.link
Instagram: http://instagram.danlok.link
Linkedin: http://mylinkedin.danlok.link
Podcast: http://thedanlokshow.danlok.link
#DanLok #BrianScudamore #DoomLoop
Please understand that by watching Dan’s videos or enrolling in his programs does not mean you’ll get results close to what he’s been able to do (or do anything for that matter).
He’s been in business for over 20 years and his results are not typical.
Most people who watch his videos or enroll in his programs get the “how to” but never take action with the information. Dan is only sharing what has worked for him and his students.
Your results are dependent on many factors… including but not limited to your ability to work hard, commit yourself, and do whatever it takes.
Entering any business is going to involve a level of risk as well as massive commitment and action. If you're not willing to accept that, please DO NOT WATCH DAN’S VIDEOS OR SIGN UP FOR ONE OF HIS PROGRAMS.
This video is about Ending The Doom Loop Explained By Multi-Millionaire Brian Scudamore
https://youtu.be/vYJi0-jGDas
https://youtu.be/vYJi0-jGDas
personal blog example 在 Melody Tam Youtube 的最讚貼文
HKDSE各科免費筆記Sample:https://www.mteducationhk.com/free_resources/
更多線上課程資訊:https://www.mteducationhk.com/
IELTS英文請參閱:https://www.mteducationielts.com/
---
Instagram
Business account: melodytamhkdse
Personal account: melodylmtam
Food blog: melomeloxdd
---
Email: admin@mteducationhk.com
WhatsApp (admin): 852 6049 1152
personal blog example 在 SiennyLoves Drawing Youtube 的最讚貼文
Hmm....Continue from Part 1, this vblog for Part 2️⃣ ~ SiennyLovesDrawing?? gonna sharing her own self day makeup ???practice in the workshop, how she did it from theory learnt & then seek guidance from instructor ??? to complete her day makeup ?
From her own learning experience & attendance, this workshop definitely worth the RM100 fee paid for a makeup beginner
Why?
She has gained a lot from the great content delivery, including able to try Focallure USA makeup products. Special thanks to product sponsor ~ Ayu La Bonita Cosmetics, the sole original distributor in Malaysia. Do check out their IG @AyuLaBonita4u for more details & purchase ya
She loves the detailed content delivery by the instructor, moreover she is very friendly & addressed clearly each questions raised to her during the workshop. The instructor also observed & helped each participants during the Part 2 own day makeup preparation
Personally she enjoyed this focus & personal guidance by instructor to help & guide on unsure application of theory to practice. For example, as shared in her vblog, she made mistakes on eyebrows drawing & contouring. Then, instructor has helped & provide clear explanation in guiding her for correct way. Really appreciate the effort by the instructor. Thank you very much, Cikgu Anna. Really enjoyed your session
Sharing some of the makeup tips learnt from the instructor,
- Don't be lazy, must clean/ wash each makeup brushes & tools used after makeup done. This is important to ensure long live usage then
- Don't ever soak your brushes while cleaning them, brushes will be spoilt
- Use of fingers for makeup application as fingers with body heat, so warm to apply shimmer on eyes & stay beautifully from 1st apply
- Use a harder brush to apply concealer when it aims for makeup correction
- When foundation too bright, do use a darken tone loose powder to balance the skin tone, vice versa
- Do apply baby oil on fake lashes 1st, it will get soften & easier to remove the lashes. Also stop the sticky from lashes glue with baby oil application. She has tried it, it works wonder. If your lashes remain pretty after being removed, do keep it for 2nd use
Ohh ya...She has gained an impressive moment before the workshop. She loves the personal reminder sent from the organizer, MPH Publishing to her WhatsApp few days before this workshop with notes for her pre-preparation before attendance as listed below,
• All makeup products & tools, including eyelashes will be provided
• To ensure face is bare, cleansed, toned & moisturized before the workshop begins. This is to avoid waste of time of removing makeup during the workshop.
• To also bring own daily make-up items so that instructor can share some advices
• To bring own hairbands/ hairpins to hold own hair for the makeup practice in the workshop
• To bring your own makeup removal, facial cleanser & towel if wish to remove makeup after
More updates ???? via her tweets main thread via ? https://twitter.com/siennylovesdraw/status/1035690689588125696?s=21
Ohh ya…Do refer https://www.facebook.com/MPHGroupPublishing/ for all future MPH publishing’s hosted events, you may attend some with SiennyLovesDrawing too
Hmm...This was her 2nd time attended, do enjoy reading her blogging of 1st workshop experience via ? https://siennylovesdrawing.wordpress.com/2018/08/23/comics-art-workshop/
Let’s continue learning new skills or knowledge ya
#Saturday #sharing #sharingiscaring #workshop #class #beauty #makeup #wellness #bepretty #female #women #females #style #styling #MPH #MPHGroupPublising #siennylovesdrawing #learning #AyuLaBonitaCosmetics #Focallure #focalluremalaysia #focalluremakeup #focallurecosmetics
personal blog example 在 Wordpress Blog with Elementor Full Tutorial for 2020 - YouTube 的推薦與評價
My Wordpress Blog Tutorial for 2020. ... Wordpress Blog with Elementor Full Tutorial for 2020 - A Customizable Personal Blog. ... <看更多>
personal blog example 在 Charca/astro-blog-template - GitHub 的推薦與評價
Personal Blog Template Powered by Astro. Contribute to Charca/astro-blog-template development by creating an account on GitHub. ... <看更多>
personal blog example 在 20 Inspiring and Creative Personal Blog Web Designs 的推薦與評價
17 Examples of Beautiful Typography in Web Design - Web Design Ledger. We will show you more examples of text over images, and also other approaches to making ... ... <看更多>