Еще один взгляд на проблему "жизнь без последовательностей"

21.12.09

Разработка - Математика и алгоритмы

Предлагаю свой взгляд на решение проблемы "документы без последовательности". Решение навеяно обсуждениями http://infostart.ru/public/62785/ и http://infostart.ru/forum/forum11/topic28666/. Даже попытался описать его там (152). Теперь думаю, что оно может быть опубликовано и самостоятельно. Я считаю это решение теоретически исчерпывающим и готовым к практическому воплощению, а что скажете Вы?

Для краткости и ясности используем язык математики.

Обозначим номенклатуру i, приход j, расход k. 

Функция X(i,j,k) определяет структуру списания, сложившуюся в интересующий нас момент t. 

То есть отвечает на вопрос - сколько номенклатуры i из прихода j было списано при расходе k. 

Функцию можно представить в виде куба со сторонами: Номенклатура, Приход, Расход. 

Исправление задним числом можно представить как функцию dX(i,j,k). Так что Xt+1(i,j,k)=Xt(i,j,k)+dX(i,j,k). 

То есть корректировка документа не должна быть перепроведением, а должна рассчитывать дельту структуры списания. 

 

Предложение объединить два измерения (номенклатуру и приход) ничего не меняет. 

В этом случае используется структура Y(l,k), где l=i*N+j. N - количество номенклатуры. 

А уравнение превращается в Yt+1(l,k)=Yt(l,k)+dY(l,k).

 

Как решается задача определения dX? 

 

Куб X делится на слои номенклатуры i: Z=X(i=i,j,k). В каждом слое применяется изменение d (уменьшается или увеличивается приход или расход или изменяется их порядок). 

Затем решается частный случай ТРАНСПОРТНОЙ ЗАДАЧИ (это разновидность задач линейного программирования) с ограничениями: 

 

Σj Zjk = Rk

 

(общий расход из всех приходов равен количеству Rk в расходной накладной k)

 

Σk Zjk <= Sj

 

 

(общий приход из всех расходов ограничен количеством Sj прихода j)

 

и целевой функцией:

 

Σjk Zjk * Cjk -> min

 

При этом для метода ФИФО, например,  коэффициенты Сjk будут определяться правилом

 

Cjk = 1/(T(k) - T(j)), если T(k) > T(j) и  Cjk = ∞, если T(k) <= T(j),

где T(j), T(k) - время прихода и расхода соответственно.

 

В качестве опорного решения берется текущее значение Z. 

Правда, так мы фактически вычисляем не dX, а непосредственно Xt+1.

 

Почему же тогда 1С использует перепроведение и последовательность? 

Потому что в этом случае не нужен отдельный алгоритм расчета dX и структуры данных под него. 

dX определяется последовательным повторением элементарных проведений одного документа, 

начиная с момента нарушения последовательности. 

Такие алгоритмы называются решением методом "грубой силы". 

Можно предложить различные частичные усовершенствования. Например, "softpoint", в котором восстановление последовательности проводится отдельно по каждому слою номенклатуры.

Можно оптимизировать хранение структуры списания. 

Хотя сам собой напрашивается регистр сведений с измерениями: Номенклатура, Приход, Расход и ресурсом Количество. 

Так раньше и хранили разреженные матрицы.

Можно поставить задачу найти самый быстрый алгоритм расчета dX. 

Сам алгоритм решения ТРАНСПОРТНОЙ ЗАДАЧИ (метод потенциалов, симплекс-метод) хорошо исследован, 

новое можно попробовать поискать в ускорении для данного частного случая задания целевой функции и опорного решения. 

Или уже учесть особенности реализации: самый быстрый с использованием промежуточных записей в БД, самый быстрый в оперативной памяти, 

самый быстрый при использовании структур данных 77 и т.п. 

 

Только сначала нужно определиться: зачем? 

 

Дело в том, что генезис платформ 1С - от бухгалтерии, от учетных задач, нацеливает решения не на отражение настоящего, а на рисование прошлого. 

Бухгалтер раскладывает на столе первичку и решает: в какой момент произвести списание? 

Когда товар был подороже или подешевле? Показывать или нет авансы? 

Ну и пусть попробует один вариант, восстановит последовательность (пересчитает себестоимость), подождет. 

Вам хочется, чтобы это делалось максимально быстро? Стоит ли овчинка выделки? Раз в месяц, раз в квартал - компьютер не перетрудится! 

В общем, к управлению, к отражению настоящего, эта задача "рисования прошлого" не относится, а значит, ИМХО не требует высокой скорости расчетов.

См. также

Логистика, склад и ТМЦ Бухгалтер Пользователь Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Оптовая торговля, дистрибуция, логистика Управленческий учет Платные (руб)

Программа позволяет организовать учет ответственного хранения товаров с весовыми характеристиками, в том числе со сроком годности и личным кабинетом Поклажедателя. Модуль реализован в виде расширения конфигурации, устанавливается в режиме 1С:Предприятие 8 за 5 минут по инструкции, что позволяет оставить конфигурацию 1С на стандартной поддержке и продолжать получать стандартные обновления от фирмы "1С".

89900 руб.

09.06.2020    38299    28    59    

64

SALE! 10%

Перенос данных 1C Взаиморасчеты Оптовая торговля Логистика, склад и ТМЦ Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Управление торговлей 10 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Управленческий учет Платные (руб)

Можно проверить до покупки, оставьте заявку! Воспользовались более 268 компаний! Перенос данных из УТ 10.3 в УТ 11 | из УТ 10.3 в КА 2 | из УТ 10.3 в ERP. Предлагаем качественное и проверенное временем решение для перехода с УТ 10.3. Можно перенести начальные остатки, нормативно-справочную информацию и все возможные документы. При выгрузке можно установить отбор по периоду, организациям и складам. При выходе новых релизов конфигураций 1C оперативно выпускаем обновление переноса данных.

50722 45650 руб.

24.04.2015    194659    149    242    

279

Бюджетирование и планирование Оптовая торговля Розничная торговля Логистика, склад и ТМЦ Анализ продаж Пользователь Платформа 1С v7.7 Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Розница 2 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Беларусь Украина Россия Казахстан Управленческий учет Платные (руб)

Система управления запасами для 1С помогает работать с запасами правильно: автоматически рассчитывает потребность и делает заказ поставщику, загружает прайсы, перемещает товары по филиалам, анализирует продажи и позволяет управлять ассортиментом.

28500 руб.

21.04.2017    96026    125    40    

214

Логистика, склад и ТМЦ Бухгалтер Пользователь Платформа 1С v8.3 Сельское хозяйство и рыболовство Строительство Горнодобывающая промышленность Розничная и сетевая торговля (FMCG) Транспорт, автопарки, такси Оптовая торговля, дистрибуция, логистика Лесное и деревообрабатывающее хозяйство Управленческий учет Платные (руб)

Позволяет автоматизировать процесс взвешивания ТМЦ в организациях, осуществляющих приемку и отгрузку различным транспортом, для ведения складского учета и контроля остатков на складах. Конфигурация позволяет фиксировать вес вручную, напрямую с весов, а также управлять дополнительным оборудованием и контролировать движение транспорта.

35000 руб.

24.03.2015    125413    301    114    

136

Логистика, склад и ТМЦ Платформа 1С v8.3 Россия Платные (руб)

Подсистема автоматизированного управления складом AS WMS для конфигураций на платформе 1С 8. AS WMS – готовое решение для эффективного управления, хранения и учета на адресном складе. Внедрение системы AS WMS способствует быстрому отбору товара, ускорению инвентаризации, снижению зависимости от персонала, исключению пересорта. AS WMS встраивается в любую конфигурацию на платформе 1С 8 и работает как единая система без обменов. В учетной системе нет необходимости менять процессы под AS WMS (например, вводить ордерную схему), AS WMS использует стандартные документы по товародвижению вашей учетной системы.

40000 руб.

26.07.2023    5787    19    0    

11

Печатные формы Логистика, склад и ТМЦ Бухгалтер Платформа 1С v8.3 Бухгалтерский учет Оперативный учет Управляемые формы 1С:Комплексная автоматизация 2.х Транспорт, автопарки, такси Оптовая торговля, дистрибуция, логистика Россия Бухгалтерский учет Управленческий учет Платные (руб)

Программа для автоматизации учета путевых листов в 1С - расширение, добавляющее в конфигурацию "Комплексная автоматизация", документ Путевой лист и печатные формы установленных образцов для легковых и грузовых авто, расчет и списание нормативного количества топлива, отчет "Реестр путевых листов" с отбором по автомобилю и по водителю (через настройки) Позволит контролировать расход топлива, потому что сразу будет виден сверхнормативный расход.

13200 руб.

27.06.2023    3698    10    1    

11

Загрузка и выгрузка в Excel Логистика, склад и ТМЦ Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Бухгалтер Пользователь Платформа 1С v8.3 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Эволюция не стоит на месте - новая удобная версия функциональной обработки для Вашего бизнеса! Что же Вы получаете? Удобный и интуитивно понятный интерфейс с 3-мя этапами работы. 2 режима - автоматический и ручной. Чтение XLSX, XLSM, CSV, XML/YML форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 10.10.2024, версия 9.8 - 9.13)

15600 руб.

20.11.2015    155552    377    377    

511
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Арчибальд 2709 21.12.09 09:22 Сейчас в теме
По-моему, в данном случае математическая модель не проясняет, а маскирует ситуацию. Поскольку никому не нужно складывать булки с отвертками, мы всегда находимся ровно в одном "слое", так что задача линейного программирования (ЗЛП) не более чем двумерна. А с учетом того, что Приход = -Расход, размерность и вовсе единична. Далее, ограничение "приход раньше расхода" на практике несущественно, ибо физически невозможна отгрузка несуществующего товара. Вот документально, даже юридически, она вполне возможна - хоть "задним числом" это назови, хоть "фьючерсным контрактом". И наконец, никакой целевой функции нет, так что это вообще не ЗЛП.
zexpress; Ёпрст; +2 Ответить
3. ildarovich 7929 21.12.09 15:26 Сейчас в теме
(1)Хорошо! Без маскировки. Вы думаете о проблеме: как вести учет, забыв о последовательностях.
Я Вам говорю, что Ваше желание сбудется, если у Вас будет таблица "структура списания", в которой для каждой номенклатуры, прихода и расхода будет отмечаться: сколько товара по этой цепочке прошло. Таблица - это регистр остатков с измерениями: номенклатура, документ прихода, документ расхода и ресурсом: количество. НадеюсЬ, Вы не будете спорить, что таблица должна быть заполнена "правильно". Эта правильность - учет ограничений: сумма количества одной номенклатуры из одного прихода во всех строках таблицы не должно быть больше исходного количества прихода; сумма количества для одного расхода в разных строках таблицы должно совпадать с количеством этой номенклатуры в этой расходной накладной; количества в строчках таблицы должно быть положительным.
Попытавшись составить это "судоку", Вы поймете, что это можно сделать гуголом различных способов. Потому, что ограничений - столько, сколько приходов + расходов, а переменных - столько, сколько приходов х расходов. Я Вам говорю, что среди этого гугола есть Ваш, единственный и наилучший способ. И говорю как его определить. Нужно минимизировать случаи, когда списывается товар с ближайшего по времени прихода, сделав это невыгодным. Штраф рассчитаем (для ФИФО) обратно пропорционально близости времени расхода и прихода, а если расход был раньше прихода сделаем штраф вообще запредельным! То есть нам будет выгоднее списывать более ранние партии для конкретного расхода. И вот этот Ваш заветный наилучший способ Вы и найдете, решив ЗЛП (точнее, ее частный случай - транспортную задачу). В процессе поиска решения сначала найдете опорное решение методом "северо-западного угла". Можете удивляться или нет, но программируя списание партий, Вы действуете точно таким же способом.
Итак, у нас есть "структура списания", полученная всего-лишь по-другому названным способом. Затраты времени на это оказались примерно теми-же. В чем же выигрыш? А вот в чем.
Кладовщик развернул рыбу - это оказалась накладная! И дата - 13-е, пятница, прошлого месяца!
Что делать? - Пересчитывать таблицу "структура списания". Как??? Да по тому же алгоритму поиска оптимального решения распределения по партиям! Всего-то и делов - одно ограничение добавилось. Метод "потенциалов" решения нового судоку работает так, что выполняет минимум итераций, если опорное решение близко к оптимуму. На выходе имеем новую "правильную" таблицу списания партий. С учетом новой накладной. И не важно - приход, расход. Если рыба в накладной была в холодильнике - мы даже не поморщились! Аналогично рассматриваются случаи изменения количества в накладных, добавления новых позиций, исключения старых. При этом контролируются остатки на любой момент! То есть ограничения не допускают никаких, хотя бы секундных "косяков". Метод просто отвергнет очередное изменение, не найдя решения!
Еще раз - мы имеем дело со всем массивом документов одновременно. Неважно, в какой последовательности изменяются документы массива - мы каждый раз перестраиваем "структуру списания". Это все равно, что при каждом нарушении последовательности востанавливать ее перепроведением. Только вместо расчета "от печки" мы быстро, за минимум итераций(отцы доказали!), переходим по граням выпуклого многоугольника ограничений симплекс-метода.
Теперь понятно?
4. tango 545 21.12.09 15:30 Сейчас в теме
(3) "Таблица - это регистр остатков с измерениями: номенклатура, документ прихода, документ расхода и ресурсом: количество."

Таблица - это регистр сведений ... без количества, поскольку вводим запись на каждую минимальную единицу учета, т.е. кол == 1

**
В измерения кроме Номенклатуры впихнем еще ЗначенияНабораХарактеристикНоменклатуры

**
В набор характеристик можно добавить число ЦенаПоступления
6. Арчибальд 2709 21.12.09 15:53 Сейчас в теме
(3) Повеселил :D
Вы думаете о проблеме: как вести учет, забыв о последовательностях
Ничего подобного я не думаю. Я это знаю и делаю. Нет у меня никаких последовательностей, и я прекрасно себя чувствую.
нам будет выгоднее списывать более ранние партии для конкретного расхода. И вот этот Ваш заветный наилучший способ Вы и найдете, решив ЗЛП

Не факт, что списание самых ранних партий всегда лучше. Но даже если и так, то после возврата части древней партии "трехмерная" оптимизация рассыплется - все последующие списания придется корректировать.
То есть ограничения не допускают никаких, хотя бы секундных "косяков". Метод просто отвергнет очередное изменение, не найдя решения
Тогда как бухгалтер/менеджер решение легко найдут...
Можете удивляться или нет
Меня удивить вряд ли получится :D
http://infostart.ru/profile/46936/blog/843/
2. kayen 21.12.09 15:06 Сейчас в теме
Интересная модель но к сожалению неприменима к жизни. Как например быть с себестоимостью в рамках конкретного периода?
5. ildarovich 7929 21.12.09 15:40 Сейчас в теме
(2) Имея актуальную "структуру списания", то есть зная: что, когда и по какому документу приходило, в каком количестве, когда и по какому документу списывалось Вы дальше можете рассчитать что угодно.
Не хотелось усложнять, но, наверное понятно, что ЛИФО будет отличаться видом целевой функции (разность времен в числителе), при среднем в таблице будет одна строка, при среднемесячном - столько, сколько месяцев и так далее.
7. CheBurator 2696 21.12.09 17:20 Сейчас в теме
прочитал бегло... так что не взыщите...
> То есть нам будет выгоднее списывать более ранние партии для конкретного расхода. И вот этот Ваш заветный наилучший способ ...
- бяка (частная). при списывании с ранних партий - при необходимости впихнуть задним числом новый расход натыкаемся на нехватку товара - так как товар с ранних партий уже списан. А вот если списывать с ближайших партий - такого не будет...
.. но это все пока написал "на бегу".. в порядке дежурного бреда...
8. ildarovich 7929 21.12.09 18:14 Сейчас в теме
(7) Слово "выгоднее" я употребил для объяснения значения параметров целевой функции. Имелось ввиду, что это требование заставит считать лучшим решение распределения партий "как при списании по ФИФО". Не имелась ввиду динамика наших действий - целевая функция определяет требование к результату, который может быть получен хоть алгоритмом случайного поиска. Про алгоритм "метод потенциала" и его реализацию я вообще не упоминал, считая, что он и так известен. Этот алгоритм довольно мудреный и, если тут еще и его описывать, вообще запутаемся. Просто считаем, что он применяется и таким образом мы переходим от одного разрешенного состояния к другому в направлении оптимума (правильно распределенных партий). Не применяя абстракции от используемого алгоритма поиска оптимального решения, нам потребуется рассматривать отдельно уменьшение прихода, увеличение прихода, уменьшение расхода, увеличение расхода, перестановку приходов, перестановку расходов. А затем просматривать "волну изменений" в "таблице списания". Этого не нужно, если на данном этапе представить алгоритм "метод потенциала" как черный ящик, дающий оптимальное решение. Возьмите хотя бы Эксель и решение транспортной задачи через подбор параметра. Там Вы не видите процесса решения - видите результат.
Математика тут применяется для того, чтобы описать, что мы хотим получить в итоге. И каким требованиям должно удовлетворять решение. Существует ли оно вообще. Это и выводит нас на общий метод решения таких задач. Дальше остаются подробности реализации. И хотя "дьявол кроется в деталях", математическая обоснованность сходимости и скорости сходимости методов ЛП, дает уверенность в получении результата.
9. Шёпот теней 1782 21.12.09 18:53 Сейчас в теме
... не согласен с :

"Обозначим номенклатуру i, приход j, расход k. Функция X(i,j,k) "

почему:

1. эта функция истинна в случае номенклатура = приходу ...
2. если номенклатура = НЕприход тогда это множество без сортировки ...
3. если мы к п.2. добавляем партии, то номенклатура превращается в двойное множество ...
4. если мы берём лифо-фифо то функции усложняется ещё и сортировкой внутри п.3 ...
5. в связи с усложнённостью функции учитывающей пп. 2,3,4 мы имеем систему охреНительной сложность ... а если ещё добавить сложность перекрёстных ссылок (влияние документов друг на друга) - то будет полная амба - типа 1С ....

... ВОТтакоеМНЕНИЕесть ...

...
10. vuzurp 22.12.09 08:46 Сейчас в теме
Что-то мне непонятно в этой прикладной математике! :D

В реальном учете (не виртуальном, не теоретическом!) у "изменения документа задним числом" одна единственная задача - привести все последующие показатели к требуемым величинам. Т.е. переделать движения всех последующих документов!

Если не требуется изменять все уже рассчитанное, то ошибочный документ прошлого периода исправляется текущей датой: сторнируются все (или отдельные) его прежние движения и записываются новые.

Механизмы для решения обеих задач существуют. Что нового предлагает обсуждаемая медота?
11. ildarovich 7929 22.12.09 11:32 Сейчас в теме
(10)
В реальном учете (не виртуальном, не теоретическом!) у "изменения документа задним числом" одна единственная задача - привести все последующие показатели к требуемым величинам. Т.е. переделать движения всех последующих документов!

Когда Вы говорите "переделать движения всех последующих документов", Вы как-будто подразумеваете, что последующий документ делает движения по регистру партий и что, не перепроводя его, ничего не сделать, поскольку нельзя (или сложно) изменить движения без перепроведения. То есть связываете себя конкретной реализацией партионного учета.
Я же смотрю на проблему в целом. Что есть регистр партий? - Всего лишь структура для определения того, из какого документа прихода взят конкретный расход (X(i,j,k)). Функция X(i,j,k) может быть реализована как угодно. И рассчитываться не обязательно последовательным проведением документов. В моем предложении - небольшими или большими (если изменение в массиве документов существенное) точечными корректировками dX(i,j,k).

Другими словами, НЕ переделать ДВИЖЕНИЯ ВСЕХ ПОСЛЕДУЮЩИХ документов, а пересчитать только измененные связи документов, возникшие из-за исходного изменения.
Механизмы для решения обеих задач существуют. Что нового предлагает обсуждаемая медота?

Я говорю только о первой задаче. Новое в том, что она сведена к известным оптимизационным задачам. В результате можем использовать готовые хорошо исследованные алгоритмы решения, которые, я, кстати, здесь не описывал, если не все это заметили!

Кроме того, предлагаемое решение не использует понятие "последовательность".

Также мне показалось ценным то, что в классе возможных алгоритмов решения определено место стандартного алгоритма 1С, а следовательно - его достоинства и недостатки относительно других методов. В итоге, я и предлагаю осознанно искать лучшие методы, зная, что мы можем выиграть и нужно ли это вообще!
12. phsin 183 23.12.09 12:47 Сейчас в теме
кажется, для 7.7 это не применимо, т.к. движения можно делать только в модуле документа. а здесь получается придется изменять движения по регистрам обработкой...
поправьте меня, если я не прав, автор предлагает восстанавливать последовательность только по тем товарам, которые изменились при проведении задним числом каким-то хитрым способом с привлечением (потусторонних сил) транспортной логистики..
хотя с теорией я увы на ВЫ, поэтому так и хочется крикнуть "Пример в студию!" ;)
13. ildarovich 7929 23.12.09 13:12 Сейчас в теме
(12) Понимаю Ваши сомнения. Намеренно хотел уйти от технических подробностей реализации, чтобы взглянуть на корень проблемы.
Вижу, без примера не все понятно. Пример подготовлю. Нужно какое-то время.
14. phsin 183 23.12.09 13:15 Сейчас в теме
15. ildarovich 7929 23.12.09 13:18 Сейчас в теме
(12)
поправьте меня, если я не прав

Вы не совсем правы. Хитрым способом я предлагаю не восстанавливать последовательность, а корректировать структуру списания X(i,j,k), которая ее заменяет. Привлекается не транспортная логистика, а математически схожая с распределением по партиям задача линейного программирования.
22. ildarovich 7929 19.08.10 09:41 Сейчас в теме
(12)(16)(19) В статье http://infostart.ru/public/74343/ описывается практическая реализация данного метода, приводятся: тестовая конфигурация, программный код, оценки быстродействия.
16. bulpi 217 23.12.09 21:27 Сейчас в теме
Уважаемый автор! Я поставил плюс за новый, свежий взгляд на известные вещи. Но должен Вас предупредить : те самые "готовые хорошо исследованные алгоритмы решения" неприятно удивят Вас своей сходимостью для случая большого количества переменных. Сам пробовал, удивлялся. Теоретически вроде все ОК, а практически до числа довести - фиг!
17. ildarovich 7929 23.12.09 22:48 Сейчас в теме
(16) Большое спасибо. Вы уловили суть дела. Но все же хочу попробовать. В данном случае критерием истины будут результаты практического исследования на задачах реальной размерности. Обнадеживает легко просматриваемое сходство с приемами ускоренного проведения по партиям.
18. hogik 443 24.12.09 02:10 Сейчас в теме
(0)
В данной статье меня заинтересовал текст после слов: "...зачем?". Я согласен с каждым утверждением этой части статьи. И попробую дополнить этот текст некоторыми деталями своего понимания задачи.
1) "...1С ...нацеливает решения не на отражение настоящего, а на рисование прошлого."
- А изменение прошлого не должно влиять на текущий процесс торговли. Как в изменении основных итоговых показателей - реальные остатки на полках и взаиморасчеты с клиентами. Так и не должны нарушать вычислительный процесс регламентными работами в сетевой (многопользовательской) среде.
2) "Бухгалтер раскладывает на столе первичку и решает: в какой момент произвести списание? Когда товар был подороже или подешевле? Показывать или нет авансы?"
- Для этого можно не раскладывать документы на столе. А дать бухгалтеру программные средства раскладки документов в компьютерной базе данных в соответствии с его пожеланиями (правилами).
3) "Ну и пусть попробует один вариант, восстановит последовательность (пересчитает себестоимость), подождет."
- Т.к. данные этого расчета (например, себестоимости) никак не влияют на "отражение настоящего", то не имеет смысла хранить эти расчеты в базе данных в момент "восстановления последовательности" прошлого периода. И, тем более не имеет смысла, нагружать систему лишней работой в момент отражения настоящего (проведение документов текущего периода). Т.е. "себестоимость" надо не пересчитывать, а считать всегда заново после перестановки документов (см. пункт #5).
4) "Вам хочется, чтобы это делалось максимально быстро? ... Раз в месяц, раз в квартал - компьютер не перетрудится!"
- Для "настоящего" требуется доступность вычислительных средств всегда. И перерыв в работе торговли, даже один раз в месяц (квартал), не допустим. Это означает, что "восстановление последовательностей" прошлого периода (для бухгалтерских нужд) должен выполняться в многопользовательской среде и не мешать реальной торговле.
5) "... эта задача "рисования прошлого" ... не требует высокой скорости расчетов."
- Сам расчет существует всегда. А быстро он выполняется, если в процессе расчета не делается перепроведение документов. Т.е. документы расставлены в соответствии с пунктом #2, а окончательные цифирьки рассчитываются и выводятся отчетом. И не хранятся в базе данных!
19. hansel 18 25.12.09 22:45 Сейчас в теме
(0) Как говорят англоязычные коллеги: if you are so clever, show me your money.
Переводя с "ихнего", и адаптируя к сути Вашей статьи: если Вы такой умный, нам код работающий покажите.

Сразу PS: Не сочтите реплику за неуважение. Будет практический результат Ваших идей - обсудим, а так - мутно всё это.
20. ildarovich 7929 25.12.09 23:38 Сейчас в теме
21. quick 584 03.03.10 14:55 Сейчас в теме
Интересная идея по поводу того что можно проверять приход за весь период с сравнивать его с предполагаемым расходом. А если без дельта и т.д. напрямую?
Приход = ПолучитьПриходЗаВесьПериод();
РасчетныйРасход = ПолучитьРасходЗаВесьПериод + КолвоСписать;
Если Приход - РасчетныйРасход < 0 Тогда
Сообщить("Списание в минус");
Подумать только как бы общий расход приход хранить для быстрого расчета.
Оставьте свое сообщение