﻿<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type='text/css' href='https://stocksharp.com/css/style.css'?>
<?xml-stylesheet type='text/css' href='https://stocksharp.com/css/bbeditor.css'?>
<feed xmlns="http://www.w3.org/2005/Atom">
  <title type="html">PositionManager.Position &amp; StrategyPositionManager.OnOrderChanged</title>
  <id>~/topic/1507/positionmanager_position--strategypositionmanager_onorderchanged/</id>
  <rights type="text">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  <updated>2026-06-10T02:41:49Z</updated>
  <logo>https://stocksharp.com/images/logo.png</logo>
  <link href="https://stocksharp.com/handlers/atom.ashx?category=topic&amp;id=1507" rel="self" type="application/rss+xml" />
  <entry>
    <id>https://stocksharp.com/posts/m/7382/</id>
    <title type="text">Ввиду с проблемой неправильного подсчета PositionManager.Position описанной здесь решил написать про...</title>
    <published>2011-04-10T15:17:49Z</published>
    <updated>2016-08-15T23:57:40Z</updated>
    <author>
      <name>bleed</name>
      <uri>https://stocksharp.com/users/28060/</uri>
      <email>info@stocksharp.com</email>
    </author>
    <content type="html">&lt;p&gt;Ввиду с проблемой неправильного подсчета PositionManager.Position описанной &lt;a href="http://stocksharp.com/forum/1469/-3-0-19--Niepravil-no-schitaietsia-Position-v-PositionManager/"&gt;здесь&lt;/a&gt;&lt;/p&gt;
&lt;p&gt;решил написать простую рабочую реализацию PositionManager для проведения тестов, по примеру который предложил Михаил по ссылке выше&lt;/p&gt;
&lt;p&gt;Итак простая реализация, как мне кажется правильного алгоритма&lt;/p&gt;
&lt;pre&gt;&lt;code&gt;    class NewPositionManager : StrategyPositionManager
    {
        public NewPositionManager(Strategy strategy, bool byOrders) : base(strategy, byOrders) {}

        protected override void OnOrderChanged(Order order)
        {
            if (TraderHelper.IsFilledEmpty(order) || TraderHelper.IsCanceled(order))
                return;
            else if (TraderHelper.IsFilledPartially(order))
            {
                //TODO
            }
            else if(TraderHelper.IsMatched(order))
            {
                base.Position += (order.Direction == OrderDirections.Buy) ? order.Volume : -1*(order.Volume);
            }

        }
    }
&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;при тестировании на обьеме в &lt;strong&gt;1&lt;/strong&gt; контракт выявила также не правильный подсчет позиции, а именно позиция ровно в &lt;strong&gt;2 раза&lt;/strong&gt; отлична от верной&lt;/p&gt;
&lt;p&gt;при отлатке через дебагер обнаружил что метод OnOrderChanged вызывается два раза для одной и тойже заявки, отсюда и неправильный подсчет..&lt;/p&gt;
&lt;p&gt;Ошибка? или чем вызван второй вызов OnOrderChanged?&lt;/p&gt;
&lt;p&gt;я просто в тупик встал, без правильного PositionManager.Position бесмысленно и стратегию писать, и вообще работать с библиотекой&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
  <entry>
    <id>https://stocksharp.com/posts/m/7389/</id>
    <title type="text">bleed: Ошибка? или чем вызван второй вызов OnOrderChanged? На это вообще закладываться нельзя. ТС шл...</title>
    <published>2011-04-11T11:32:33Z</published>
    <updated>2011-04-11T11:32:33Z</updated>
    <author>
      <name>Mikhail Sukhov</name>
      <uri>https://stocksharp.com/users/201/</uri>
      <email>info@stocksharp.com</email>
    </author>
    <content type="html">&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;&lt;a href="@message(7382)" rel="nofollow" target="_blank"&gt;bleed&lt;/a&gt;:&lt;/strong&gt;
Ошибка? или чем вызван второй вызов OnOrderChanged?&lt;/p&gt;
&lt;/blockquote&gt;
&lt;p&gt;На это вообще закладываться нельзя. ТС шлет сообщения об изменении исходя из своей внутренней логики. Делайте словарь с проверкой.&lt;/p&gt;
&lt;p&gt;Насчет баги. На этой неделе постараюсь выложить новую версию с фиксами.&lt;/p&gt;
</content>
    <rights type="html">Copyright @ StockSharp Platform LLC 2010 - 2025</rights>
  </entry>
</feed>