Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

Andytick

Building a VolumeProfile Indicator with EasyLanguage

Recommended Posts

hey, that is great if can do it without loops, I stand corrected :applaud:

 

Historically, I have just let the raw numbers get fed into excel and just save it -- and then manipulate them that way -- I find that very customizable -- so if yesterdays or the day before data is out of the current range, I just hide those columns and present the data that way... or however you would like to do it. Having the raw numbers makes it so you can do anything you want easily.

Share this post


Link to post
Share on other sites
hey, that is great if can do it without loops, I stand corrected :applaud:

 

Historically, I have just let the raw numbers get fed into excel and just save it -- and then manipulate them that way -- I find that very customizable -- so if yesterdays or the day before data is out of the current range, I just hide those columns and present the data that way... or however you would like to do it. Having the raw numbers makes it so you can do anything you want easily.

 

Ok Frank, you have done a good thing........for you, but I'd like to do it in the easylanguage way and not excel. I'd like to have my informations all in 1 chart and not one in excel, the other in my platform, the other again in Multicharts and so on.

So the excel way is not in my interest. Sorry

Thanks for your contribution too.

 

I don't know if there will be loops or not, I have not to demonstrate nothing to anyone but what is in my interest is that the code could be useful to everyone who would like to have it, potentially light, quick loadable and accurate to the tick, so everyone who could bring his contribution to this work will be very appreciated

Share this post


Link to post
Share on other sites
hey, that is great if can do it without loops, I stand corrected :applaud:

 

Historically, I have just let the raw numbers get fed into excel and just save it -- and then manipulate them that way -- I find that very customizable -- so if yesterdays or the day before data is out of the current range, I just hide those columns and present the data that way... or however you would like to do it. Having the raw numbers makes it so you can do anything you want easily.

 

If I could manage to get whet you manage to out of excel I'd probably do it like that too!

Share this post


Link to post
Share on other sites

arrays are memory resident,

they can be a memory hog, if you have multi-multi-dimensional arrays.

but in terms of updating arrays, even in loops, should not pose a problem with today's computer.

 

one of my indicator has a 770x5 array.

it updates itself (loop) a couple of times per bar.

I am running this indicator in multiple charts,

I too was concerned with speed when first I implement this indicator,

so far I have not seen any CPU spikes.

Edited by Tams

Share this post


Link to post
Share on other sites
arrays are memory resident,

they can be a memory hog, if you have multi-multi-dimensional arrays.

 

so are a couple thousand variables, by trying not

forcing them into some weird function by having an "end;" statement in your script

if the same can be achieved by an "end else" and they are just fine, even with loops.

more important is to check the logic of the script once done and see if maybe somewhere

you could replace a loop by a simple counter and see if it doesnt force to much.

Share this post


Link to post
Share on other sites

I must be away for some days for a sudden emergency not foreseen.

I will think about some way to build the Volume profile histogram in this days.

I'll be back in 4 - 5 days.

 

Thanks again to all for your contribution

AndyTick

Share this post


Link to post
Share on other sites
arrays are memory resident,

they can be a memory hog, if you have multi-multi-dimensional arrays.

but in terms of updating arrays, even in loops, should not pose a problem with today's computer.

 

one of my indicator has a 770x5 array.

it updates itself (loop) a couple of times per bar.

I am running this indicator in multiple charts,

I too was concerned with speed when first I implement this indicator,

so far I have not seen any CPU spikes.

 

If it is only updating a couple of times a day thats all fine and dandy! but for building accurate volume profiles you need to be updating the arrays every tick. Horses for courses I guess :D

 

For example because TS and MC dont have 'tick precise' technology where you can build indicators tick by tick on historical data I will simply use (for example) a week of single tick's to build a weekly picture. (I do this for VWAP and SD's sometimes) and also PVP.

 

An alternate way would be to use say 2 minute bars and only update every 2 minutes. You would average the volume from high to low of the 2 minute bar. This will give quite different results for the peak volume than a tick by tick approach which is why I developed this code.

 

Of course whatever works for you! But I can say all the existing VWAP and PVP code essentially locks up on a lot of bars! Maybe it would recover eventually when it catches up but it is horribly inefficient. Even the vol histogram code in the first post can take minutes to load on a couple of days of minute bars.

Share this post


Link to post
Share on other sites
If it is only updating a couple of times a day thats all fine and dandy! but for building accurate volume profiles you need to be updating the arrays every tick. Horses for courses I guess :D

 

For example because TS and MC dont have 'tick precise' technology where you can build indicators tick by tick on historical data I will simply use (for example) a week of single tick's to build a weekly picture. (I do this for VWAP and SD's sometimes) and also PVP.

 

An alternate way would be to use say 2 minute bars and only update every 2 minutes. You would average the volume from high to low of the 2 minute bar. This will give quite different results for the peak volume than a tick by tick approach which is why I developed this code.

 

Of course whatever works for you! But I can say all the existing VWAP and PVP code essentially locks up on a lot of bars! Maybe it would recover eventually when it catches up but it is horribly inefficient. Even the vol histogram code in the first post can take minutes to load on a couple of days of minute bars.

Hi guys, I'm back again.

I think that a 2 minute bar is not a good thing for an accurate Volume Profile Indicator. Even with PVP and VWAP it's not good so I usually use as Blowfish a tick chart to calculate a weekly PVP and VWAP.

A good way to calculte an History of Volume Profile indicator without increasing the CPU performance and time spending, could be using ADE.

You could save the yesterday Volume profile in a txt file and then call back every new day, so you have to calcultare only then new day Volume Profile Histogram and you have each past days stored as a txt file so it could be loaded faster than calculate and loading each day of the chart.

The volume profile is saved as a txt file in a specified directory and call back by the ADE.

I've not reached the way to calculate the Volume Profile, but we can try some ways and then evaluate the better way in terms of time to load and CPU usage. Then after creating a starting point we could improve it step by step.

This is my thought.

Share this post


Link to post
Share on other sites

Here is my last code based on the Blowfish/DBntina original code about PVP loaded in 1 tick chart (load more than 1 day to make it work).

Thinking about the original code in these days I've understood some things ( late is better than never).

1) They start in the middle of the array because the function on which the array is based, can't have a negative value (V2VolLevel can be negative). The code logic base the prices levels on the starting value adding or subtracting N tick factor and referring to each price level the Volume .

ORIGINAL CODE:

If date = date[1] And StartPrice > 0 Then Begin

Value2 = AvgPrice - StartPrice;

V2VolLevel = 5000+(Value2*(1/(minmove/pricescale))); //this value can be negative so they start the count in the positive middle of the array

PVPVolArray[V2VolLevel] = PVPVolArray[V2VolLevel] + MyVolume;

 

In this way the code is quick to load even in a tick chart because the price is + or - from the starting tick (AvgPrice) on each new tick .

 

Now the origianl code calculate very weell the single PVP Volume and single PVP price level, but I've to calculate the Volume to each price level so I need a Loop anyway.

"I've changed some names to the variables " and some logic in the code.

Vars: StartPrice(0),

minD(0),

MAXD(0),

iPrice(0),

jPrice(0),

iVolume(0),

PVPPrice(0),

PVPVolume(0),

MyVolume(0),

TickFactor(0),

TickDistance(0),

PriceDiff(0);

 

Array: VolArray[10000](0);

 

MyVolume = iff(bartype < 2, (upticks+Downticks),Volume);

 

// Reset Each day at the first TICK

if Date > Date[1] then begin

StartPrice = AvgPrice;

minD = AvgPrice;

MAXD = AvgPrice;

iPrice = AvgPrice;

 

For Value1 = 0 to 10000 begin //reset the Array each day

VolArray[value1] = 0;

END;

 

PVPPrice = AvgPrice;

PVPVolume = MyVolume;

END;

 

// Calculate the value for the rest of the day past the first TICK

If Date = Date[1] and StartPrice > 0 then begin

Value2 = AvgPrice - StartPrice;

TickFactor = (minmove/PriceScale);

TickDistance = (Value2 / TickFactor);

iPrice = StartPrice + TickDistance; //this calculate each price fererred to the start price adding or subtracting N tick Factor

VolArray[iPrice] = VolArray[iPrice] + MyVolume; //this collects volume on each new tick and summ Volume with previous volume

 

// This is to identify the peak of Volume of the day and its Price level as Blowfish and DBntina coded first

if VolArray[iPrice] > PVPVolume then begin

PVPVolume = VolArray[iPrice];

PriceDiff = StartPrice - iPrice;

PVPPrice = StartPrice - (PriceDiff * TickFactor);

END;

 

// Now I've to identify the price Range of the day in Tick Factor

//identify MAX of the day and min of the day in tickFactor

If iPrice >= MAXD then begin

MAXD = iPrice;

end;

If iPrice <= minD then begin

minD = iPrice;

end;

 

//Loop the Volume sum from the min of the day to the MAx of the day

For jPrice = minD to (MAXD-1) begin

if jPrice = iPrice then

VolArray[jPrice] = VolArray[iPrice]+ MyVolume;

end;

iVolume = VolArray[jPrice]; // This is the Volume at each iPrice level

 

//Here I create a Print log in a txt file to control the code (minD ; MAXD ; iVolume)

 

Print(File("C:/temp/VolumeProfile.txt")," ",numtostr(date, 0)," ", numtostr(time,0)," ",numtostr(iPrice,0)," ",numtostr(iVolume,0));

Print(File("C:/temp/MAXD.txt")," ",numtostr(date, 0)," ", numtostr(time,0)," ",text(MAXD,0));

Print(File("C:/temp/minD.txt")," ",numtostr(date, 0)," ", numtostr(time,0)," ",text(minD,0));

 

END;

 

It seems to work fine, but from the print log txt file I can't have a single price level whith its single volume level. There are reduntant price levels and not a single price level for each price.

Where I'm wrong ?

Share this post


Link to post
Share on other sites

This seems better :

 

For iPrice = minD to (MAXD-1) begin

 

if AvgPrice = iPrice then

VolArray[iPrice] = VolArray[iPrice]+ MyVolume;

 

end;

iVolume = VolArray[iPrice]; // This is the Volume at each price level

 

 

Suggestions are well appreciated ;)

Share this post


Link to post
Share on other sites

I Must take a step back and riconsider one thing analyzing the print log file in txt format.

I don't need a loop as posted in the last 2 post, because the original code do it itself.

On each price level the code sums new volume to past volume with each new tick comes.

SO now, how to have only the last cumulative volume on a single price level and not the sequence of each single volume from the first to the last ?

How can I separate the last cumulative volume of each price level ?

Here is the code:

Vars: StartPrice(0),

minD(0),

MAXD(0),

iPrice(0),

jPrice(0),

iVolume(0),

PVPPrice(0),

PVPVolume(0),

MyVolume(0),

TickFactor(0),

TickDistance(0),

PriceDiff(0);

 

Array: VolArray[10000](0);

 

MyVolume = Volume;

 

// Reset Each day at the first TICK

if Date > Date[1] then begin

StartPrice = AvgPrice;

minD = AvgPrice;

MAXD = AvgPrice;

iPrice = AvgPrice;

 

For Value1 = 0 to 10000 begin

VolArray[value1] = 0;

END;

 

PVPPrice = AvgPrice;

PVPVolume = MyVolume;

END;

 

// Calculate the value for the rest of the day past the first TICK

If Date = Date[1] and StartPrice > 0 then begin

Value2 = AvgPrice - StartPrice;

TickFactor = (minmove/PriceScale);

TickDistance = (Value2 *(1/ TickFactor));

iPrice = StartPrice + TickDistance;

VolArray[iPrice] = VolArray[iPrice] + MyVolume; //this collects volume at each new tick and sum Volume with previous volume on each price level

 

// The VolArray[iPrice] is the cumulative volume at price Array

// the sequence of cumulative Volume on each price

// Not only the last cumulative Volume, but the sequence to the last

// How to have only the LAST cumulative Volume ??

 

// This is to identify the peak of Volume of the day and its Price level

if VolArray[iPrice] > PVPVolume then begin

PVPVolume = VolArray[iPrice];

PriceDiff = StartPrice - iPrice;

PVPPrice = StartPrice - (PriceDiff * TickFactor);

END;

 

 

//identify MAX of the day and min of the day in tickFactor

If iPrice >= MAXD then begin

MAXD = iPrice;

end;

If iPrice <= minD then begin

minD = iPrice;

end;

 

 

Print(File("C:/temp/VolumeProfile.txt")," ",numtostr(date, 0)," ", numtostr(time,0)," ",numtostr(iPrice,0)," ",numtostr(VolArray[iPrice],0));

 

 

END;

 

Plot1(PVPPrice, "PVPPrice");

Plot2(PVPVolume, "PVPVolume");

 

 

Suggestion will be very appreciated, Please !!!

The code will be useful to many in the forum.

Share this post


Link to post
Share on other sites
note: if you use the CODE TAG (the # icon) instead of QUOTE TAG...

you will preserve the code formating in the code window.

 

Sorry, You are right, I've clicked on the wrong icon and I've not noticed until now.

Sorry again

 

Vars: StartPrice(0),
     minD(0),
     MAXD(0),
     iPrice(0),
     jPrice(0),
     iVolume(0),
     PVPPrice(0),
     PVPVolume(0),
     MyVolume(0),
     TickFactor(0),
     TickDistance(0),
     PriceDiff(0);

Array: VolArray[10000](0);


MyVolume = Volume;

// Reset Each day at the first TICK
if Date > Date[1] then begin
StartPrice = AvgPrice;
minD = AvgPrice;
MAXD = AvgPrice;
iPrice = AvgPrice;

For Value1 = 0 to 10000 begin
   VolArray[value1] = 0;
   END;


PVPPrice = AvgPrice;
PVPVolume = MyVolume;
iVolume = MyVolume;
END;

// Calculate the value for the rest of the day past the first TICK
If Date = Date[1] and StartPrice > 0 then begin
   Value2 = AvgPrice - StartPrice;
   TickFactor = (minmove/PriceScale);
   TickDistance = (Value2 *(1/ TickFactor));
   iPrice = StartPrice + TickDistance;
   VolArray[iPrice] = VolArray[iPrice] + MyVolume; //this collects volume at each new tick and summ Volume with previous volume

   // Thsi is to identify the peak of Volume of the day and its Price level
   if VolArray[iPrice] > PVPVolume then begin
   PVPVolume = VolArray[iPrice];
   PriceDiff = StartPrice - iPrice;
   PVPPrice = StartPrice - (PriceDiff * TickFactor);
   END;


   //identify MAX of the day and min of the day in tickFactor
   If iPrice >= MAXD then begin
       MAXD = iPrice;
   end;
   If iPrice <= minD then begin
       minD = iPrice;
   end;


   If VolArray[iPrice] > VolArray[iPrice][1] then begin
      iVolume = VolArray[iPrice];         // This identify the last iVolume
   end;

   Print(File("C:/temp/VolumeProfile.txt"),"  ",numtostr(date, 0),"  ", numtostr(time,0),"  ",numtostr(iPrice,0),"  ",numtostr(iVolume,0));


END;

Plot1(PVPPrice, "PVPPrice");
Plot2(PVPVolume, "PVPVolume");

Share this post


Link to post
Share on other sites
Not sure you really need a loop at all. Take another look at http://www.traderslaboratory.com/forums/56/building-volumeprofile-indicator-easylanguage-7073-2.html#post79526

 

If you go for fixed scaling all you need to do is re-plot the appropriate histo bar of the array element you have just updated.

 

Yes Blowfish you are right.

I already have what I need. Now I'd like to find a good way to plot it using ASCII mapping as symbol to plot in a sequence of symbols, as "------" or "*****" .

Each symbol must reflect a chunk. I'm tring a way to do this.

I'm also thinking about using ADE to save the previous days Histogram in a txt file in a directory. So I can load only a few tick data or days like 2 or 3 days to calculate the last day and retrieve the others old ones by ADE.

In this way I could calculate not only a daily volume histogram, but also a weekly volume histogram, saving the past days in a directory as Txt files using ADE.

It would be a great thing and it would use only a few resources of memory and cpu loading all in a few second or moments. It wouldn't take much time to load all using ADE and I could plot the daily histogram also on a 5 minutes or N volume chart, not only on a 1 tick chart. The tick chart could be used only to generate or calculate the daily histogram, then it could be plotted on a different resolution chart using ADE.

First I have to find a good way to plot it using ASCII mapping and not Trend lines as the GKmarketprofile in the first post.

Share this post


Link to post
Share on other sites

Just wonder why you want ascii? Is it simply a visual appeal thing. To be honest I am not familiar with line plot functions but don't they have higher 'resolution'. Can they plot to the pixel or only to the bar? I rather like lines over ascii. Each to there own though :)

Share this post


Link to post
Share on other sites
Just wonder why you want ascii? Is it simply a visual appeal thing. To be honest I am not familiar with line plot functions but don't they have higher 'resolution'. Can they plot to the pixel or only to the bar? I rather like lines over ascii. Each to there own though :)

 

There are 2 reasons why I prefer ASCII:

First I know that you can plot a limited numbers of lines (trendLines) in a chart, so if I'd like to plot a daily histogram on many days, it would limit my plot.

 

Second it's a personal preference and in my opinion ASCII mapping like "------------" is easier to save with ADE and quicker to load as indicator than TLines, but its just my opinion.

Here form the first post 2 different resolutions using lines and ASCII:

2qx6e1d.png

 

soy4pg.png

Share this post


Link to post
Share on other sites
Just wonder why you want ascii? Is it simply a visual appeal thing. To be honest I am not familiar with line plot functions but don't they have higher 'resolution'. Can they plot to the pixel or only to the bar? I rather like lines over ascii. Each to there own though :)

 

A third reason is becouse ASCII is referred to pixel and TL commands are reffered to bars.

Share this post


Link to post
Share on other sites
can you use the GKMarketProfileTL indicator to identify the PVP?

sorry if this sounds stupid but im new to easylanguage

 

thanks

 

..... what is PVP?

 

how is it calculated?

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Similar Content

    • By FMIND5
      Hello traders,
      I am interested in order flow trading and I will post some trades and predictions, some articles and ideology of a bit different understanding how price moves and why. May be this forum will be the right place. So, for the start I have  couple of charts of recent trade on oil. Also I did some comparison of two different software. Would be great to meet some traders who use order flow too. Lets see. I have a lots ideas and strategies to share. I don't use any traditional indicators, because just numbers are important for me.
       
       
       


    • By trading4life
      Hello, My name is trading4life.
      I just joined this forum.
  • Topics

  • Posts

    • also ... and barely on topic... Winners (always*) overpay. Buying the dips is a subscription to the belief that winners win by underpaying - when in actuality winners (inevitably/always*) win by overpaying... it’s amazing the percentage of traders who think winners win by underpaying ... “Winners (always*) overpay.” ...  One way to implement this ‘belief’ is to only reenter when prices have emphatically resumed the 'trend' .   (Fwiw, While “Winners (always*) overpay.” holds true in most endeavors (relationships, business, sports, etc...) - “Winners (always*) overpay.”  is especially true for auctions... continuous auctions included.)
    • re:  "Does it make sense to always buy the dips?  “Buy the dip.”  You hear this all the time in crypto investing trading speculation gambling. [zdo taking some liberties] It refers, of course, to buying more bitcoin (or digital assets) when they go down in price: when the price “dips.” Some people brag about “buying the dip," showing they know better than the crowd. Others “buy the dip” as an investment strategy: they’re getting a bargain. The problem is, buying the dip is a fallacy. You can’t buy the dip, because you can't see the total dip until much later. First, I’ll explain this in a way that will make it simple and obvious to you; then I’ll show you a better way of investing. You Only Know the Dip in Hindsight When people talk about “buying the dip,” what they’re really saying is, “I bought when the price was going down.” " ... example of a dip ... 
    • Date: 19th April 2024. Weekly Commodity Market Update: Oil Prices Correct and Supply Concerns Persist.   The ongoing developments in the Middle East sparked a wave of risk aversion and fueled supply concerns and investors headed for safety. Hopes for imminent rate cuts from the Federal Reserve diminish while attention is now turning towards the demand outlook. The Gold price hit a high of $2417.89 per ounce overnight. Sentiment has already calmed down again and bullion is trading at $2376.50 per ounce as haven flows ease. Oil prices initially moved higher as concern over escalating tensions with the WTI contract hit a session high of $85.508 per barrel overnight, before correcting to currently $81.45 per barrel. Oil Prices Under Pressure Amid Middle East Tensions Last week, commodity indexes showed little movement, with Oil prices undergoing a slight correction. Meanwhile, Gold reached yet another record high, mirroring the upward trend in cocoa prices. Once again today, USOil prices experienced a correction and has remained under pressure, retesting the 50-day EMA at $81.00 as we moving into the weekend. Hence, despite the Israel’s retaliatory strike on Iran, sentiments stabilized following reports suggesting a measured response aimed at avoiding further escalation. Brent crude futures witnessed a more than 4% leap, driven by concerns over potential disruptions to oil supplies in the Middle East, only to subsequently erase all gains. Similarly with USOIL, UKOIL hovers just below $87 per barrel, marginally below Thursday’s closing figures. Nevertheless, volatility is expected to continue in the market as several potential risks loom:   Disruption to the Strait of Hormuz: The possibility of Iran disrupting navigation through the vital shipping lane, is still in play. The Strait of Hormuz serves as the Persian Gulf’s primary route to international waters, with approximately 21 million barrels of oil passing through daily. Recent events, including Iran’s seizure of an Israel-linked container ship, underscore the geopolitical sensitivity of the region. Tougher Sanctions on Iran: Analysts speculate that the US may impose stricter sanctions on Iranian oil exports or intensify enforcement of existing restrictions. With global oil consumption reaching 102 million barrels per day, Iran’s production of 3.3 million barrels remains significant. Recent actions targeting Venezuelan oil highlight the potential for increased pressure on Iranian exports. OPEC Output Increases: Despite the desire for higher prices, OPEC members such as Saudi Arabia and Russia have constrained output in recent years. However, sustained crude prices above $100 per barrel could prompt concerns about demand and incentivize increased production. The OPEC may opt to boost oil output should tensions escalate further and prices surge. Ukraine Conflict: Amidst the focus on the Middle East, markets overlooking Russia’s actions in Ukraine. Potential retaliatory strikes by Kyiv on Russian oil infrastructure could impact exports, adding further complexity to global oil markets.   Technical Analysis USOIL is marking one of the steepest weekly declines witnessed this year after a brief period of consolidation. The breach below the pivotal support level of 84.00, coupled with the descent below the mid of the 4-month upchannel, signals a possible shift in market sentiment towards a bearish trend reversal. Adding to the bearish outlook are indications such as the downward slope in the RSI. However, the asset still hold above the 50-day EMA which coincides also with the mid of last year’s downleg, with key support zone at $80.00-$81.00. If it breaks this support zone, the focus may shift towards the 200-day EMA and 38.2% Fib. level at $77.60-$79.00. Conversely, a rejection of the $81 level and an upside potential could see the price returning back to $84.00. A break of the latter could trigger the attention back to the December’s resistance, situated around $86.60. A breakthrough above this level could ignite a stronger rally towards the $89.20-$90.00 zone. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Michalis Efthymiou Market Analyst HMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past perfrmance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • Date: 18th April 2024. Market News – Stock markets benefit from Dollar correction. Economic Indicators & Central Banks:   Technical buying, bargain hunting, and risk aversion helped Treasuries rally and unwind recent losses. Yields dropped from the recent 2024 highs. Asian stock markets strengthened, as the US Dollar corrected in the wake of comments from Japan’s currency chief Masato Kanda, who said G7 countries continue to stress that excessive swings and disorderly moves in the foreign exchange market were harmful for economies. US Stockpiles expanded to 10-month high. The data overshadowed the impact of geopolitical tensions in the Middle East as traders await Israel’s response to Iran’s unprecedented recent attack. President Joe Biden called for higher tariffs on imports of Chinese steel and aluminum.   Financial Markets Performance:   The USDIndex stumbled, falling to 105.66 at the end of the day from the intraday high of 106.48. It lost ground against most of its G10 peers. There wasn’t much on the calendar to provide new direction. USDJPY lows retesting the 154 bottom! NOT an intervention yet. BoJ/MoF USDJPY intervention happens when there is more than 100+ pip move in seconds, not 50 pips. USOIL slumped by 3% near $82, as US crude inventories rose by 2.7 million barrels last week, hitting the highest level since last June, while gauges of fuel demand declined. Gold strengthened as the dollar weakened and bullion is trading at $2378.44 per ounce. Market Trends:   Wall Street closed in the red after opening with small corrective gains. The NASDAQ underperformed, slumping -1.15%, with the S&P500 -0.58% lower, while the Dow lost -0.12. The Nikkei closed 0.2% higher, the Hang Seng gained more than 1. European and US futures are finding buyers. A gauge of global chip stocks and AI bellwether Nvidia Corp. have both fallen into a technical correction. The TMSC reported its first profit rise in a year, after strong AI demand revived growth at the world’s biggest contract chipmaker. The main chipmaker to Apple Inc. and Nvidia Corp. recorded a 9% rise in net income, beating estimates. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Andria Pichidi Market Analyst HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
    • Date: 17th April 2024. Market News – Appetite for risk-taking remains weak. Economic Indicators & Central Banks:   Stocks, Treasury yields and US Dollar stay firmed. Fed Chair Powell added to the recent sell off. His slightly more hawkish tone further priced out chances for any imminent action and the timing of a cut was pushed out further. He suggested if higher inflation does persist, the Fed will hold rates steady “for as long as needed.” Implied Fed Fund: There remains no real chance for a move on May 1 and at their intraday highs the June implied funds rate future showed only 5 bps, while July reflected only 10 bps. And a full 25 bps was not priced in until November, with 38 bps in cuts seen for 2024. US & EU Economies Diverging: Lagarde says ECB is moving toward rate cuts – if there are no major shocks. UK March CPI inflation falls less than expected. Output price inflation has started to nudge higher, despite another decline in input prices. Together with yesterday’s higher than expected wage numbers, the data will add to the arguments of the hawks at the BoE, which remain very reluctant to contemplate rate cuts. Canada CPI rose 0.6% in March, double the 0.3% February increase BUT core eased. The doors are still open for a possible cut at the next BoC meeting on June 5. IMF revised up its global growth forecast for 2024 with inflation easing, in its new World Economic Outlook. This is consistent with a global soft landing, according to the report. Financial Markets Performance:   USDJPY also inched up to 154.67 on expectations the BoJ will remain accommodative and as the market challenges a perceived 155 red line for MoF intervention. USOIL prices slipped -0.15% to $84.20 per barrel. Gold rose 0.24% to $2389.11 per ounce, a new record closing high as geopolitical risks overshadowed the impacts of rising rates and the stronger dollar. Market Trends:   Wall Street waffled either side of unchanged on the day amid dimming rate cut potential, rising yields, and earnings. The major indexes closed mixed with the Dow up 0.17%, while the S&P500 and NASDAQ lost -0.21% and -0.12%, respectively. Asian stock markets mostly corrected again, with Japanese bourses underperforming and the Nikkei down -1.3%. Mainland China bourses were a notable exception and the CSI 300 rallied 1.4%, but the MSCI Asia Pacific index came close to erasing the gains for this year. Always trade with strict risk management. Your capital is the single most important aspect of your trading business. Please note that times displayed based on local time zone and are from time of writing this report. Click HERE to access the full HFM Economic calendar. Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Andria Pichidi Market Analyst HFMarkets Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in FX and CFDs products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.vvvvvvv
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.