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.

aaa

Round a Price with a Fraction (1/2)

Recommended Posts

Hello

 

I'd like to round a price like this ;

 

7980,5 instead of 7980.40 or 7980,60

 

With Excel there is a way to round a price with a fraction (1/2)

 

Is there something similar in EL ?

 

Thank you

Share this post


Link to post
Share on other sites

Round

 

Returns the value of one specified numerical expression rounded to the number of decimal places specified by another.

 

Usage

 

Round(Value,Precision)

 

Where:

Value - a numerical expression

Precision - a numerical expression

 

Examples

 

Round(1.237,2) will return a value of 1.24

 

Round(-5.7744,3) will return a value of –5.774

Share this post


Link to post
Share on other sites

I use this function but is there a way to round as a fraction ?

 

Round(1.237,2) will return a value of 1.24

 

1.24 = 1.0

 

Round(-5.7744,3) will return a value of –5.774

 

–5.774 = -6.0

 

7981 instead of 7980.76 or 7981.24

 

7980,5 instead of 7980.26 or 7980,74

 

7980 instead of 7980.24 or 7979.76

Share this post


Link to post
Share on other sites

it is because I always have to choose quickly when I buy or sell

 

If I round to 0 I miss the half or I pay half more...

 

I hope that I'm clear enough...

Share this post


Link to post
Share on other sites

I'm wondering if it is possible to make a function called RoundFraction

 

Pseudo Code

 

if decimal >= .00 and < .024 then decimal = 0

 

if decimal >= .25 and < .074 then decimal = 0.5

 

if decimal >= .75 and < 1.0 then decimal = 0 and number +1

 

If someone knows how to code that it'll be very kind.

Share this post


Link to post
Share on other sites
I'm wondering if it is possible to make a function called RoundFraction

 

Pseudo Code

 

if decimal >= .00 and < .024 then decimal = 0

 

if decimal >= .25 and < .074 then decimal = 0.5

 

if decimal >= .75 and < 1.0 then decimal = 0 and number +1

 

If someone knows how to code that it'll be very kind.

 

This should do it... Create a new numeric function called RoundFraction and copy and paste the code below into it.

 

inputs: Number(NumericSimple);

vars: Fraction(0);

Fraction = FracPortion(Number);

If Fraction > 0 and Fraction < 0.24 then RoundFraction = 0;
If Fraction >= 0.25 and Fraction < 0.74 then RoundFraction = 0.5;
If Fraction > 0.75 then RoundFraction = 1;

 

You can use it as follows:

vars: 	val1(20.2),
val2(20.4),
val3(20.8),
Result(0);

{Result = 20.0)}
Result = RoundFraction(val1) + IntPortion(val1); 
Print("Result = ", Result);

{Result = 20.5)}
Result = RoundFraction(val2) + IntPortion(val1); 
Print("Result = ", Result);

{Result = 21)}
Result = RoundFraction(val3) + IntPortion(val1); 
Print("Result = ", Result);

 

The output of above code...

 

Result = 20.00

Result = 20.50

Result = 21.00

Share this post


Link to post
Share on other sites

ThanX SEVENSA

 

I appreciate your help and I hope that this function will be usefull for the community

 

For me it is exactly what I was looking for a while

Share this post


Link to post
Share on other sites

// RoundFraction

// Version 1.00 by SEVENSA

// Version 1.01

// minor changes in the formula

// Date: 20090320

//-----------------------------------------------------

inputs:

//----------------------------------------------------

 

Number(NumericSimple);

 

//----------------------------------------------------------------

variables:

//----------------------------------------------------------------

 

Fraction(0);

 

Fraction = FracPortion(Number);

 

 

If Fraction >= 0 and Fraction < 0.25 then

RoundFraction = 0;

 

If Fraction >= 0.25 and Fraction < 0.75 then

RoundFraction = 0.5;

 

If Fraction >= 0.75 then

RoundFraction = 1;

 

{

vars: val1(20.2),

val2(20.4),

val3(20.8),

Result(0);

 

{Result = 20.0)}

Result = RoundFraction(val1) + IntPortion(val1);

Print("Result = ", Result);

 

{Result = 20.5)}

Result = RoundFraction(val2) + IntPortion(val1);

Print("Result = ", Result);

 

{Result = 21)}

Result = RoundFraction(val3) + IntPortion(val1);

Print("Result = ", Result);

}

Share this post


Link to post
Share on other sites

The way I would do it is double the original price round it to zero decimal places and half it. I think the syntax should be correct....didn't check it.

 

value1 = round(2*close,0)/2;

 

That's just me...contrary :D

 

Edit if you want quarters replace 2 with 4 - eighths replace 2 with 8 etc.

Edited by BlowFish

Share this post


Link to post
Share on other sites

Every now and then I get nostalgic about the good old days. (most people move to the next post about then) Many many years ago I used to work as a software engineer. Coding in assembler (and working with smart people) exposes you to all sorts of neat tricks and tips. Actually after a while you actually start to think differently when it comes to programmatic problems.

 

Multiplying and dividing by powers of two (2,4,8,16 etc.) can be achieved by bitwise operators, rotate left, and rotate right. Rotating and adding was a common way of doing arithmetic in the days before processors had dedicated hardware to do floating point arithmetic.

Share this post


Link to post
Share on other sites
The way I would do it is double the original price round it to zero decimal places and half it. I think the syntax should be correct....didn't check it.

 

value1 = round(2*close,0)/2;

 

That's just me...contrary :D

 

Edit if you want quarters replace 2 with 4 - eighths replace 2 with 8 etc.

 

You are such a show off. :)

Share this post


Link to post
Share on other sites

The results of the Pivots doesn't match with Excel...

 

R1 = Round( 2 * ( 2 * PP - DailyLow ), 0 ) / 2 ;

R2 = Round( 2 * ( PP + Range ) , 0 ) / 2 ;

R3 = Round( 2 * ( R2 + Range ) , 0 ) / 2 ;

R4 = Round( 2 * ( R3 + Range ) , 0 ) / 2 ;

S1 = Round( 2 * ( 2 * PP - DailyHigh ) , 0 ) / 2 ;

S2 = Round( 2 * ( PP - Range ) , 0 ) / 2 ;

S3 = Round( 2 * ( S2 - Range ) , 0 ) / 2 ;

S4 = Round( 2 * ( S3 - Range ) , 0 ) / 2 ;

Share this post


Link to post
Share on other sites

I have the same wrong result with my method

 

I trust more Excel because it's so simple

 

I notice that from PP to R4 is correct

 

Strange

 

But from S1 to S4 is wrong (half a point)

 

R1 = RoundFraction( 2 * PP - DailyLow ) + IntPortion( 2 * PP - DailyLow ) ;

R2 = RoundFraction( PP + Range ) + IntPortion( PP + Range ) ;

R3 = RoundFraction( R2 + Range ) + IntPortion( R2 + Range ) ;

R4 = RoundFraction( R3 + Range ) + IntPortion( R3 + Range ) ;

S1 = RoundFraction( 2 * PP - DailyHigh ) + IntPortion( 2 * PP - DailyHigh ) ;

S2 = RoundFraction( PP - Range ) + IntPortion( PP - Range ) ;

S3 = RoundFraction( S2 - Range ) + IntPortion( S2 - Range ) ;

S4 = RoundFraction( S3 - Range ) + IntPortion( S3 - Range ) ;

Share this post


Link to post
Share on other sites

I think that it's because it computes 2 rounds

 

PP is rounded then used to compute S1 wich is also rounded

 

The same for the others Pivots

Share this post


Link to post
Share on other sites

Bingo

 

This one matches perfectly with Excel

 

PP = Round( 2 * ( DailyHigh + DailyLow + ClotCompense ) / 3 , 0 ) / 2

 

R1 = Round( 2 * ( 2 * ( DailyHigh + DailyLow + ClotCompense ) / 3 - DailyLow ) , 0 ) / 2 ;

R2 = Round( 2 * ( ( DailyHigh + DailyLow + ClotCompense ) / 3 + Range ) , 0 ) / 2 ;

R3 = Round( 2 * ( ( DailyHigh + DailyLow + ClotCompense ) / 3 + Range + Range ) , 0 ) / 2 ;

R4 = Round( 2 * ( ( DailyHigh + DailyLow + ClotCompense ) / 3 + Range + Range + Range ) , 0 ) / 2 ;

S1 = Round( 2 * ( 2 * ( DailyHigh + DailyLow + ClotCompense ) / 3 - DailyHigh ) , 0 ) / 2 ;

S2 = Round( 2 * ( ( DailyHigh + DailyLow + ClotCompense ) / 3 - Range ) , 0 ) / 2 ;

S3 = Round( 2 * ( ( DailyHigh + DailyLow + ClotCompense ) / 3 - Range - Range ) , 0 ) / 2 ;

S4 = Round( 2 * ( ( DailyHigh + DailyLow + ClotCompense ) / 3 - Range - Range - Range ) , 0 ) / 2 ;

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.


  • Topics

  • Posts

    • NFLX Netflix stock watch, local support and resistance areas at 838.12 and 880.5 at https://stockconsultant.com/?NFLX
    • NFLX Netflix stock watch, local support and resistance areas at 838.12 and 880.5 at https://stockconsultant.com/?NFLX
    • Hello citizens of the U.S. The hundred year trade war has leaked over into a trading war. Your equity holdings are under attack by huge sovereign funds shorting relentlessly... running basically the opposite of  PPT operations.  As an American you are blessed to be totally responsible for your own assets - the govt won’t and can’t take care of you, your lame ass whuss ‘retail’ fund managers go catatonic  and can't / won’t help you, etc etc.... If you’re going to hold your positions, it’s on you to hedge your holdings.   Don’t blame Trump, don’t blame the system, don’t even blame the ‘enemies’ - ie don’t blame period.  Just occupy the freedom and responsibility you have and act.  The only mistake ‘Trump’ made so far was not to warn you more explicitly and remind you of your options to hedge weeks ago.   FWIW when Trump got elected... I also failed to explicitly remind you... just sayin’
    • Date: 7th April 2025.   Asian Markets Plunge as US-China Trade War Escalates; Wall Street Futures Signal Further Turmoil.   Global financial markets extended last week’s massive sell-off as tensions between the US and its major trading partners deepened, rattling investors and prompting sharp declines across equities, commodities, and currencies. The fallout from President Trump’s sweeping new tariff measures continued to spread, raising fears of a full-blown trade war and economic recession.   Asian stock markets plunged on Monday, extending a global market rout fueled by rising tensions between the US and China. The latest wave of aggressive tariffs and retaliatory measures has unnerved investors worldwide, triggering sharp sell-offs across the Asia-Pacific region.   Asian equities led the global rout on Monday, with dramatic losses seen across the region. Japan’s Nikkei 225 index tumbled more than 8% shortly after the open, while the broader Topix fell over 6.5%, recovering only slightly from steeper losses. In mainland China, the Shanghai Composite sank 6.7%, and the blue-chip CSI300 dropped 7.5% as markets reopened following a public holiday. Hong Kong’s Hang Seng Index opened more than 9% lower, reflecting deep concerns about escalating trade tensions.           South Korea’s Kospi dropped 4.8%, triggering a circuit breaker designed to curb panic selling. Taiwan’s Taiex index collapsed by nearly 10%, with major tech exporters like TSMC and Foxconn hitting circuit breaker limits after each fell close to 10%. Meanwhile, Australia’s ASX 200 shed as much as 6.3%, and New Zealand’s NZX 50 lost over 3.5%.   Despite the escalation, Beijing has adopted a measured tone. Chinese officials urged investors not to panic and assured markets that the country has the tools to mitigate economic shocks. At the same time, they left the door open for renewed trade talks, though no specific timeline has been set.   US Stock Futures Plunge Ahead of Monday Open   US stock futures pointed to another brutal day on Wall Street. Futures tied to the S&P 500 dropped over 3%, Nasdaq futures sank 4%, and Dow Jones futures lost 2.5%—equivalent to nearly 1,000 points. The Nasdaq Composite officially entered a bear market on Friday, down more than 20% from its recent highs, while the S&P 500 is nearing bear territory. The Dow closed last week in correction. Oil prices followed suit, with WTI crude dropping over 4% to $59.49 per barrel—its lowest since April 2021.   Wall Street closed last week in disarray, erasing more than $5 trillion in value amid fears of an all-out trade war. The Nasdaq Composite officially entered a bear market on Friday, sinking more than 20% from its recent peak. The S&P 500 is approaching bear territory, and the Dow Jones Industrial Average has slipped firmly into correction territory.   German Banks Hit Hard Amid Escalating Trade Tensions   German banking stocks were among the worst hit in Europe. Shares of Commerzbank and Deutsche Bank plunged between 9.5% and 10.3% during early Frankfurt trading, compounding Friday’s steep losses. Fears over a global trade war and looming recession are severely impacting the financial sector, particularly export-driven economies like Germany.   Eurozone Growth at Risk   Eurozone officials are bracing for economic fallout, with Greek central bank governor Yannis Stournaras warning that Trump’s tariff policy could reduce eurozone GDP by up to 1%. The EU is preparing retaliatory tariffs on $28 billion worth of American goods—ranging from steel and aluminium to consumer products like dental floss and luxury jewellery.   Starting Wednesday, the US is expected to impose 25% tariffs on key EU exports, with Brussels ready to respond with its own 20% levies on nearly all remaining American imports.   UK Faces £22 Billion Economic Blow   In the UK, fresh research from KPMG revealed that the British economy could shrink by £21.6 billion by 2027 due to US-imposed tariffs. The analysis points to a 0.8% dip in economic output over the next two years, undermining Chancellor Rachel Reeves’ growth agenda. The report also warned of additional fiscal pressure that may lead to future tax increases and public spending cuts.   Wall Street Braces for Recession   Goldman Sachs revised its US recession probability to 45% within the next year, citing tighter financial conditions and rising policy uncertainty. This marks a sharp jump from the 35% risk estimated just last month—and more than double January’s 20% projection. J.P. Morgan issued a bleaker outlook, now forecasting a 60% chance of recession both in the US and globally.   Global Leaders Respond as Trade Tensions Deepen   The dramatic market sell-off was triggered by China’s sweeping retaliation to a new round of US tariffs, which included a 34% levy on all American imports. Beijing’s state-run People’s Daily released a defiant statement, asserting that China has the tools and resilience to withstand economic pressure from Washington. ‘We’ve built up experience after years of trade conflict and are prepared with a full arsenal of countermeasures,’ it stated.   Around the world, policymakers are responding to the growing threat of a trade-led economic slowdown. Japanese Prime Minister Shigeru Ishiba announced plans to appeal directly to Washington and push for tariff relief, following the US administration’s decision to impose a blanket 24% tariff on Japanese imports. He aims to visit the US soon to present Japan’s case as a fair trade partner.   In Taiwan, President Lai Ching-te said his administration would work closely with Washington to remove trade barriers and increase purchases of American goods in an effort to reduce the bilateral trade deficit. The island's defence ministry has also submitted a new list of US military procurements to highlight its strategic partnership.   Economists and strategists are warning of deeper economic consequences. Ronald Temple, chief market strategist at Lazard, said the scale and speed of these tariffs could result in far more severe damage than previously anticipated. ‘This isn’t just a bilateral conflict anymore — more countries are likely to respond in the coming weeks,’ he noted.   Analysts at Barclays cautioned that smaller Asian economies, such as Singapore and South Korea, may face challenges in negotiating with Washington and are already adjusting their economic growth forecasts downward in response to the unfolding trade crisis.           Oil Prices Sink on Demand Concerns   Crude oil continued its sharp slide on Monday, driven by recession fears and weakened global demand. Brent fell 3.9% to $63.04 a barrel, while WTI plunged over 4% to $59.49—both benchmarks marking weekly losses exceeding 10%. Analysts say inflationary pressures and slowing economic activity may drag demand down, even though energy imports were excluded from the latest round of tariffs.   Vandana Hari of Vanda Insights noted, ‘The market is struggling to find a bottom. Until there’s a clear signal from Trump that calms recession fears, crude prices will remain under pressure.’   OPEC+ Adds Further Pressure with Output Hike   Bearish sentiment intensified after OPEC+ announced it would boost production by 411,000 barrels per day in May, far surpassing the expected 135,000 bpd. The alliance called on overproducing nations to submit compensation plans by April 15. Analysts fear this surprise move could undo years of supply discipline and weigh further on already fragile oil markets.   Global political risks also flared over the weekend. Iran rejected US proposals for direct nuclear negotiations and warned of potential military action. Meanwhile, Russia claimed fresh territorial gains in Ukraine’s Sumy region and ramped up attacks on surrounding areas—further darkening the outlook for markets.   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 of how markets work. Click HERE to register for FREE!   Click HERE to READ more Market news.   Andria Pichidi 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 Leveraged 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.
    • AMZN Amazon stock watch, good buying (+313%) toi hold onto the 173.32 support area at https://stockconsultant.com/?AMZN
×
×
  • Create New...

Important Information

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