﻿<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type='text/css' href='https://stocksharp.ru/css/style.css'?>
<?xml-stylesheet type='text/css' href='https://stocksharp.ru/css/bbeditor.css'?>
<feed xmlns="http://www.w3.org/2005/Atom">
  <title type="html">Частичное исполнение лимитной заявки</title>
  <id>~/topic/8327/chastichnoe-ispolnenie-limitnoi-zayavki/</id>
  <rights type="text">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  <updated>2026-06-27T20:25:00Z</updated>
  <logo>https://stocksharp.ru/images/logo.png</logo>
  <link href="https://stocksharp.ru/handlers/atom.ashx?category=topic&amp;id=8327" rel="self" type="application/rss+xml" />
  <entry>
    <id>https://stocksharp.ru/posts/m/40184/</id>
    <title type="text">Есть событие WhenRegistered,,, В этот момент заявка имеет статус Act ive. 2, Могу рекомендовать след...</title>
    <published>2017-06-20T14:18:17Z</published>
    <updated>2017-06-20T14:18:17Z</updated>
    <author>
      <name>Support</name>
      <uri>https://stocksharp.ru/users/97869/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;ol&gt;
&lt;li&gt;Есть событие  WhenRegistered,,, В этот момент заявка имеет статус Act ive. 2, Могу рекомендовать следующий подход.. Для каждого &amp;quot;логического&amp;quot; типа заявок (вход, тейк, стоп и т.п.) создается метод, в котором собраны все события для данной заявки... В событиях заявки реализуется необходимая логика.. Можно иметь шаблон такого метода и использовать его в разных стратегиях. Ниже показан пример..&lt;/li&gt;
&lt;/ol&gt;
&lt;div class="spoiler"&gt;
&lt;pre&gt;&lt;code&gt;   private void TakeOrderProcessing(Order order)
    {

        if (_isStopping)
            return;

        order.Comment = &amp;quot;Take&amp;quot;;

        try
        {

            if (this.Root.SessionState != eSessionState.ActiveSession)
                throw new Exception(&amp;quot;Не могу выставить заявку - сессия неактивна!&amp;quot;);

            order.WhenChanged(this.Connector).Do(o =&amp;gt;
            {
                this.AddDebugLog(&amp;quot;{0} заявка изменена. {1}&amp;quot;, o.Comment, o);

                var bl = ETSBlocks.FirstOrDefault(b =&amp;gt; b.Take.Orders.Any(ord =&amp;gt; ord.TransactionId == o.TransactionId));
                if (bl != null)
                    Take.CanChange = bl.Take.Orders.Any(ord =&amp;gt; ord.State == OrderStates.Active);

            }).Apply(this);

            order.WhenRegistered(this.Connector).Do(o =&amp;gt;
            {

                var bl = ETSBlocks.FirstOrDefault(b =&amp;gt; b.Take.Orders.Any(ord =&amp;gt; ord.TransactionId == o.TransactionId));

                if (bl != null)
                    Take.CanChange = bl.Take.Orders.Any(ord =&amp;gt; ord.State == OrderStates.Active);


                this.AddDebugLog(&amp;quot;{0} заявка зарегистрирована. {1}&amp;quot;, o.Comment, o);
            }).Apply(this).Once();

            var orderWhenRegisterFailed = order.WhenRegisterFailed(this.Connector);

            orderWhenRegisterFailed.Do(of =&amp;gt;
            {
                this.AddWarningLog(&amp;quot;Ошибка регистрации {0} заявки. {1}. {2}&amp;quot;, of.Order.Comment, of.Order, of.Error.Message);
                this.Rules.RemoveRulesByToken(orderWhenRegisterFailed.Token, orderWhenRegisterFailed);
            }).Apply(this);

            var orderWhenCanceled = order.WhenCanceled(this.Connector);

            orderWhenCanceled.Do(o =&amp;gt;
            {
                this.AddInfoLog(&amp;quot;Отменена {0} заявка. {1}&amp;quot;, o.Comment, o);

                var bl = ETSBlocks.FirstOrDefault(b =&amp;gt; b.Take.Orders.Any(ord =&amp;gt; ord.TransactionId == o.TransactionId));

                if (bl != null)
                {

                    Take.CanChange = bl.Take.Orders.Any(ord =&amp;gt; ord.State == OrderStates.Active);

                    if (AlgorithmStatus == AlgorithmStatuses.SendCancelTake)
                    {


                        if (bl.Take.Orders.All(t =&amp;gt; t.State != OrderStates.Active))
                        {
                            var vol = Volume - bl.Take.Orders.Sum(t =&amp;gt; t.Volume - t.Balance);

                            var newTake = this.CreateOrder(Direction.Invert(), _newTakePrice, vol);

                            bl.Take.ActivateLevel = _newTakePrice;
                            bl.Take.Orders.Add(newTake);

                            this.AddInfoLog(&amp;quot;Изменение тейк-заявки. Послылаем команда на выставление новой тейк-заявки. Новая цена {0}&amp;quot;, _newTakePrice);

                            TakeOrderProcessing(newTake);
                        }

                    }
                }
                else
                    this.AddWarningLog(&amp;quot;Не найден TakeStopBlock&amp;quot;);

                UpdateInfo();

                this.Rules.RemoveRulesByToken(orderWhenCanceled.Token, orderWhenCanceled);
            }).Apply(this);

            var orderWhenMatched = order.WhenMatched(this.Connector);
            orderWhenMatched.Do(o =&amp;gt;
            {
                this.AddInfoLog(&amp;quot;Полное исполнение {0} заявки. {1}&amp;quot;, o.Comment, o);

                var bl = ETSBlocks.FirstOrDefault(b =&amp;gt; b.Take.Orders.Any(ord =&amp;gt; ord.TransactionId == o.TransactionId));

                if (bl != null)
                {
                    Take.CanChange = bl.Take.Orders.Any(ord =&amp;gt; ord.State == OrderStates.Active);
                    var enterVolume = bl.Enter.Orders.Where(ord =&amp;gt; ord.State == OrderStates.Done).Sum(ord =&amp;gt; ord.Volume - ord.Balance);
                    var takeVolume = bl.Take.Orders.Where(ord =&amp;gt; ord.State == OrderStates.Done).Sum(ord =&amp;gt; ord.Volume - ord.Balance);

                    if (enterVolume == takeVolume)
                        AlgorithmStatus = AlgorithmStatuses.Take;

                }
                else
                    this.AddWarningLog(&amp;quot;Не найден TakeStopBlock&amp;quot;);

                UpdateInfo();

                this.Rules.RemoveRulesByToken(orderWhenMatched.Token, orderWhenMatched);
            }).Apply(this);

            order.WhenPartiallyMatched(this.Connector).Do(o =&amp;gt;
            {
                if (o.IsMatchedPartially())
                {
                    this.AddInfoLog(&amp;quot;Частичное исполнение {0} заявки. {1}&amp;quot;, o.Comment, o);
                }
            }).Apply(this);

            order.WhenNewTrade(this.Connector).Do(trade =&amp;gt;
            {
                var bl = ETSBlocks.FirstOrDefault(b =&amp;gt; b.Take.Orders.Any(o =&amp;gt; o.TransactionId == trade.Order.TransactionId));
                if (bl != null)
                {
                    if (bl.Take.Trades.All(t =&amp;gt; t.Trade.Id != trade.Trade.Id))
                        bl.Take.Trades.Add(trade);
                }

                UpdateInfo();

            }).Apply(this);

            AlgorithmStatus = AlgorithmStatuses.SendTake;

            this.RegisterOrder(order);

            this.AddInfoLog(&amp;quot;Послана {0} заявка. Price: {0}&amp;quot;, order.Comment, order.Price);
        }
        catch (Exception ex)
        {
            this.AddErrorLog(string.Format(&amp;quot;{0} / {1}&amp;quot;, ex.Message, ex.StackTrace));
        }

    } 
&lt;/code&gt;&lt;/pre&gt;
&lt;/div&gt;</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.ru/posts/m/40179/</id>
    <title type="text">А как это реализуется на практике через собственные флаги? Я имею ввиду как дождаться, того, что выс...</title>
    <published>2017-06-19T17:49:47Z</published>
    <updated>2017-06-19T17:49:47Z</updated>
    <author>
      <name>Knup</name>
      <uri>https://stocksharp.ru/users/50721/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;p&gt;А как это реализуется на практике через собственные флаги? Я имею ввиду как дождаться, того, что выставленная заявка станет активной, чтобы к ней можно было применить CancelOrder ? Просто не совсем очевидно.&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.ru/posts/m/40177/</id>
    <title type="text">Лучше использовать два события WhenPartyallyMatched и WhenNewTrade, потому что WhenPartyallyMatched ...</title>
    <published>2017-06-19T15:50:37Z</published>
    <updated>2017-06-19T15:50:37Z</updated>
    <author>
      <name>Support</name>
      <uri>https://stocksharp.ru/users/97869/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;ol&gt;
&lt;li&gt;Лучше использовать два события WhenPartyallyMatched и WhenNewTrade, потому что WhenPartyallyMatched обычно приходит раньше WhenNewTrade... В WhenNewTrade мы только проверяем была ли выполнена обработка в WhenPartyallyMatched.. 2. Вам не нужно полностью полагаться на статусы и события зяявки, а использовать собственные флаги для контроля за состоянием...которые проверить&lt;/li&gt;
&lt;/ol&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.ru/posts/m/40174/</id>
    <title type="text">Добрый день, Подскажите, пожалуйста, как на S# корректно реализовать следующий алгоритм: Выставляем ...</title>
    <published>2017-06-19T13:08:18Z</published>
    <updated>2017-06-19T13:08:18Z</updated>
    <author>
      <name>Knup</name>
      <uri>https://stocksharp.ru/users/50721/</uri>
      <email>info@stocksharp.ru</email>
    </author>
    <content type="html">&lt;p&gt;Добрый день,&lt;/p&gt;
&lt;p&gt;Подскажите, пожалуйста, как на S# корректно реализовать следующий алгоритм:&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;Выставляем лимитную заявку на покупку&lt;/li&gt;
&lt;li&gt;При каждом частичном исполнении заявки выставляется тейк-профит в виде противоположной лимитной заявки. Тейк-профит должен быть всегда один, т.е. при каждом новом частичном исполнении заявки старый тейк-профит отменяется, новый же с сальдированным большим объёмом - выставляется. И так, пока заявка на покупку полностью не исполнится. Т.е. в итоге после исполнения лимитной заявки на покупку из n лотов должна быть одна противоположная заявка на продажу (тейк-профит) тоже из n лотов.&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;Делаю примерно так через WhenNewTrade:&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;
...
_orderOpen.WhenNewTrade(Connector)
                .Do(o =&amp;gt;
                {
                    // фиксируем набранную позицию
                    _summVolumeOpen += o.Trade.Volume;
                    _summPriceVolumeOpen += _orderdata.OpenPrice * o.Trade.Volume;

                    // Создать заявку тейк-профит по набранной позиции
                    CreateTakeProfitOrderSell(_summVolumeOpen);
                })
                .Apply(this);
...

        private void CreateTakeProfitOrderSell(decimal curvol)
        {
            lock (_syncObjSafe)
            {
                if (_orderClose != null &amp;amp;&amp;amp; _orderClose.State == OrderStates.Active)
                    CancelOrder(_orderClose);
                
                _orderClose = this.SellAtLimit(_orderdata.ClosePrice, curvol);
                
                ...

                RegisterOrder(_orderClose);
            }
        }

&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;Проблема в том, что при исполнении лимитной заявки по частям WhenNewTrade вызывается быстро несколько раз так, что заявка тейк-профит _orderClose не успевает принять состояние Active и поэтому не отменяется. WhenPartiallyMatched, как я понял, тоже не решает проблему - это правило вызывается столько же раз, сколько и WhenNewTrade. В общем, в результате вместо одного тейк-профита у меня выставляется сразу несколько, что неправильно (все заявки кроме последней должны быть отменёнными).&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
</feed>