Topics
Replies

firemyst
07 Jul 2023, 03:29

Good place to start:

 


@firemyst

firemyst
07 Jul 2023, 03:24

Why not post the code you have so people can correct it?

 

In a nutshell:

1) set your time zone in your indicator if you choose:

    [Indicator(AccessRights = AccessRights.None, TimeZone = TimeZones.AtlanticStandardTime)]

2) get your time Server.Time or if you want your local computer's DateTime.Now

3) compare that the hour of the time you got is >= 8 && <= 9

4) if 3 is true, Chart.DrawHorizontalLine on whatever value you want at 8 and 9am prices. Depending on the chart you're using, you may need to get tick data as opposed to the chart's time frame (eg, if you use something like Range or Renko, you can't depend on a bar's time as a new bar may not open/close on the exact hours)


@firemyst

firemyst
07 Jul 2023, 03:15

//just provide the source to the dataseries parameter when creating the RSI in your code:

RelativeStrengthIndex _rsi = Indicators.RelativeStrengthIndex([the data series of the symbol/timeframe you want the rsi to act upon], Periods);

 


@firemyst

firemyst
07 Jul 2023, 03:12

You're using the .Last incorrectly.

.Last should have an index indicator how many bars back you want.

 

If you want the last (most recent) value, then you need to use either:

.Last(0)

.LastValue

 


@firemyst

firemyst
05 Jul 2023, 03:24

You need to post any suggestions here:

 


@firemyst

firemyst
05 Jul 2023, 03:23

One way to do it is you need to keep track of your engulfing candles. You might want to use something like two Dictionary<int,double>() objects (one for bull candles and one for bear candles) where the key is the "bar's index" and the value is the high/low of the price.

On every new bar:

1) check every value in the bullish dictionary

2) if current price > the price of an entry in the dictionary (each value), a) delete the indicator icon at the specified bar (the key value) and b) delete the key/value pair from the dictionary as you know you don't have to check it ever again.

3) repeat steps 1-2 above for the bearish dictionary

4) if the previous bar is a bullish engulfing candle add the bar's index as the "key" to the bullish dictionary with the high price as the "value"

5) if the previous bar is a bearish engulfing candle add the bar's index as the "key" to the bearish dictionary with the low price as the "value"

 


@firemyst

firemyst
04 Jul 2023, 11:00

Hypothetically what you could do is:

//To find a bearish fractal in a range:
int startIndex = 4;
int endIndex = 7;
array.Skip(startIndex).Take(endIndex - startIndex).Max();

And see if the middle value of the array is equal the max value returned. If so, it's a bearish fractal.

note that according to the definition of a bearish fractal is as follows from Investopedia:

  • bearish turning point occurs when there is a pattern with the highest high in the middle and two lower highs on each side.

     

It doesn't say each high has to be lower/higher than the previous/next. Only that the one in the middle has to be the highest/lowest. So given that interepretation, you could use the sample code I put in at the top here.

If you do want it with each candle getting consecutively higher/lower from the middle one, I don't know how you do that without looping over each value.


@firemyst

firemyst
04 Jul 2023, 02:29

What you should try doing is looking at how others have done it, and adapt your code as appropriate.

For example:

 

 


@firemyst

firemyst
04 Jul 2023, 02:18

You're not going to get any help since you haven't posted any information.

What error messages are you receiving in the logging tab?

What have you tried doing in your code to try and find the issues?

Is it on Windows 10 or 11?

A VPS?

etc etc

 

 


@firemyst

firemyst
04 Jul 2023, 02:17

Your list is great and you've given thought to these.

 

However, what I would do (and I know this is tedious) is break them up and post the suggestions one by one. This way, users can vote on individual suggestions for Spotware to implement instead of one big list that probably won't garner nearly as many votes or people reading.

For instance, if someone votes on this list, what item in particular are they voting for? Nobody knows.

 


@firemyst

firemyst
04 Jul 2023, 02:15

Your suggestion would hold more weight and be more noticeable to Spotware if you decided to post this suggestion where it belongs (in the suggestion forum) instead of a technical help forum.

 

 


@firemyst

firemyst
03 Jul 2023, 03:44

RE:

sadiqbashir14 said:

We need more customized indicators, especially useful indicators like fluidetrades in the tradingview and many others.

Then

1) look for them in the repository:

2) write them yourself

3) ask in the indicator forum if there's someone willing to do it for you

4) or contact someone like @PanagiotisChar or @ClickAlgo who will have them developed for you for a cost.


@firemyst

firemyst
02 Jul 2023, 08:00

 

 


@firemyst

firemyst
02 Jul 2023, 07:58

Adding a link to your suggestion for others to vote on this feature:

 


@firemyst

firemyst
30 Jun 2023, 17:46

How do you even know it's getting past this to enter trades?

 

if (!istimecorrect)
                    return;

 

????

 

You need to put Print statements to see if it even gets past that return statement.


@firemyst

firemyst
30 Jun 2023, 17:24

//Try this
if (Account.MarginLevel.HasValue && Account.MarginLevel >= MarginRequirement)
  //execute your order
}
else
{
    if (!Account.MarginLevel.HasValue)
        Print("Margin Level has no value.");
    else
       //print out your margin levels so you can actually see what it is
       Print("Margin Level is {0}", Account.MarginLevel);
}

 


@firemyst

firemyst
30 Jun 2023, 09:42

RE: RE:

AlexFrei said:

 

Hi Firemyst, thank you so much !! I didnt know about History collection. Great. Thanks ! Have a great day

 

No worries. That's what the forums are for :-)


@firemyst

firemyst
30 Jun 2023, 03:33

You can do it in a position closing event method. Rough example below:

 

//In the OnStart method:
Positions.Closed += Positions_Closed;


//In the method itself once the event is defined:
private void Positions_Closed(PositionClosedEventArgs args)
{
     Position p1 = args.Position;
    //do whatever you have to do

    //Now get the historical trade stuff.
    HistoricalTrade ht = History.FindLast(p1.Label, p1.SymbolName, p1.TradeType);
    Print("Position \"{0} {1}\" closed for reason \"{2}\" with {3} profit. Entry Price {4}, Closing Price {5}, StopLoss {6}, ClosingTime {7}", p1.Id, p1.Label, args.Reason, String.Format("{0:$#,###.00}", p1.GrossProfit), p1.EntryPrice, p1.ClosingPrice, p1.StopLoss, ht.ClosingTime);

    //finish off whatever you have to do
}

 


@firemyst

firemyst
29 Jun 2023, 03:43

This suggestion is already here if you'd vote on it instead of starting another thread and splitting votes:

 


@firemyst

firemyst
29 Jun 2023, 03:41

How about posting this "help" question in the forum where it belongs?

 


@firemyst