ФЕДЕРАЛЬНОЕ АГЕНТСТВО ПО ОБРАЗОВАНИЮ Государственное образовательное учреждение высшего профессионального образования «П...
4 downloads
161 Views
923KB Size
Report
This content was uploaded by our users and we assume good faith they have the permission to share this book. If you own the copyright to this book and it is wrongfully on our website, we offer a simple DMCA procedure to remove your content from our site. Start by pressing the button below!
Report copyright / DMCA form
ФЕДЕРАЛЬНОЕ АГЕНТСТВО ПО ОБРАЗОВАНИЮ Государственное образовательное учреждение высшего профессионального образования «ПЕНЗЕНСКИЙ ГОСУДАРСТВЕННЫЙ УНИВЕРСИТЕТ»
А.А.Черный
АВТОРСКИЕ ПРАВА НА ПРОИЗВЕДЕНИЯ НАУКИ, ПРОГРАММЫ ДЛЯ ЭВМ Учебное пособие
Пенза 2010
УДК 347
Черный А.А. Авторские права на произведения науки, программы для ЭВМ: Учеб. пособие. – Пенза: Изд-во Пенз. гос. ун-та, 2010. - 300 с.
Рассмотрены авторские права на произведения науки, программы для ЭВМ. Изложены применительно к инженерным дисциплинам основные положения авторских прав. Приведены примеры интеллектуальных разработок автора, контрольные вопросы. Учебное пособие подготовлено на кафедре «Сварочное, литейное производство и материаловедение» и в Научно-исследовательском институте плавки литейных сплавов при Пензенском государственном университете. Оно предназначено для студентов всех форм обучения по специальности «Машины и технология литейного производства» и других инженерных специальностей. Его можно использовать при выполнении творческих работ.
Рецензенты: Научный совет Пензенского научного центра; А.С.Белоусов, главный металлург ОАО «Пензадизельмаш»
©
А.А.Черный, 2010
2
ВВЕДЕНИЕ Интеллектуальный труд является основой научно-технического прогресса. Выполняются все новые и новые авторские разработки. Однако авторские права разработчиков новшеств зачастую защищаются недостаточно. Это связано как с незнанием разработчиками действующих законодательств, так и с недостатками рекламы, внедрения новшеств в производство, их использования, невыгодной продажей внутри страны и за рубежом. Реклама новых разработок, поиск покупателей, заключение лицензионных соглашений, договоров, выполнение договорных обязательств организованы не на должном уровне. Многие новые разработки бывают незащищены. Творческие разработки авторов могут использовать с выгодой для себя лица, не связанные с творческим трудом. Нарушения авторских прав, а также других законов, защищающих творческий труд, приносят большие убытки авторам и государству. Следовательно, защита интеллектуальной собственности очень актуальна, надо знать, как эффективно защищать эту собственность. В данной работе изложены авторские права на произведения науки, программы для ЭВМ в соответствии с Гражданским Кодексом, который вступил в силу 1 января 2008 года [1]. Приведены примеры интеллектуальных разработок автора. Даны контрольные вопросы. Учебное пособие подготовлено применительно к изучению курса «Защита интеллектуальной собственности» студентами инженерных специальностей. Оно может быть полезно при выполнении творческих работ.
3
ОСНОВНЫЕ ПОЛОЖЕНИЯ АВТОРСКИХ ПРАВ Основные положения Интеллектуальные права на произведения науки являются авторскими правами. Автору произведения принадлежат следующие права: 1) исключительное право на произведение; 2) право авторства; 3) право автора на имя; 4) право на неприкосновенность произведения; 5) право на обнародование произведения. Автору произведения принадлежат другие права, в том числе право на вознаграждение за использование служебного произведения, право на отзыв, право следования, право доступа к произведениям. Исключительное право на произведения науки: 1) на произведения, обнародованные на территории Российской Федерации или необнародованные, но находящиеся в какой-либо объективной форме на территории Российской Федерации, и признается за авторами (их правопреемниками) независимо от их гражданства; 2) на произведения, обнародованные за пределами территории Российской Федерации или необнародованные, но находящиеся в какойлибо объективной форме за пределами территории Российской Федерации, и признается за авторами, являющимися гражданами Российской Федерации (их правопреемниками); 3) на произведения, обнародованные за пределами территории Российской Федерации или необнародованные, но находящиеся в какойлибо объективной форме за пределами территории Российской Федерации, и признается на территории Российской Федерации за авторами (их правопреемниками) - гражданами других государств и лицами без гражданства в соответствии с международными договорами Российской Федерации. Произведение также считается впервые обнародованным путем опубликования в Российской Федерации, если в течение тридцати дней после даты первого опубликования за пределами территории Российской Федерации оно было опубликовано на территории Российской Федерации. При предоставлении на территории Российской Федерации охраны произведению в соответствии с международными договорами Российской Федерации автор произведения или иной первоначальный правообладатель определяется по закону государства, на территории которого имел место
4
юридический факт, послуживший основанием для приобретения авторских прав. Предоставление на территории Российской Федерации охраны произведениям в соответствии с международными договорами Российской Федерации осуществляется в отношении произведений, не перешедших в общественное достояние в стране происхождения произведения вследствие истечения установленного в такой стране срока действия исключительного права на эти произведения и не перешедших в общественное достояние в Российской Федерации вследствие истечения срока действия исключительного права на них. При предоставлении охраны произведениям в соответствии с международными договорами Российской Федерации срок действия исключительного права на эти произведения на территории Российской Федерации не может превышать срок действия исключительного права, установленного в стране происхождения произведения. Автором произведения науки признается гражданин, творческим трудом которого оно создано. Лицо, указанное в качестве автора на оригинале или экземпляре произведения, считается его автором, если не доказано иное. Граждане, создавшие произведение совместным творческим трудом, признаются соавторами независимо от того, образует ли такое произведение неразрывное целое или состоит из частей, каждая из которых имеет самостоятельное значение. Произведение, созданное в соавторстве, используется соавторами совместно, если соглашением между ними не предусмотрено иное. В случае, когда такое произведение образует неразрывное целое, ни один из соавторов не вправе без достаточных оснований запретить использование такого произведения. Часть произведения, использование которой возможно независимо от других частей, то есть часть, имеющая самостоятельное значение, может быть использована ее автором по своему усмотрению, если соглашением между соавторами не предусмотрено иное. Каждый из соавторов вправе самостоятельно принимать меры по защите своих прав, в том числе в случае, когда созданное соавторами произведение образует неразрывное целое. Объектами авторских прав являются произведения науки, литературы и искусства независимо от достоинств и назначения произведения, а также от способа его выражения. К объектам авторских прав относятся программы для ЭВМ, которые охраняются как литературные произведения. К объектам авторских прав относятся:
5
1) производные произведения, то есть произведения, представляющие собой переработку другого произведения; 2) составные произведения, то есть произведения, представляющие собой по подбору или расположению материалов результат творческого труда. Авторские права распространяются как на обнародованные, так и на необнародованные произведения, выраженные в какой-либо объективной форме, в том числе в письменной, устной форме (в виде публичного произнесения, публичного исполнения и иной подобной форме), в форме изображения, в форме звуко- или видеозаписи, в объемнопространственной форме. Для возникновения, осуществления и защиты авторских прав не требуется регистрация произведения или соблюдение каких-либо иных формальностей. В отношении программ для ЭВМ и баз данных возможна регистрация, осуществляемая по желанию правообладателя. Авторские права не распространяются на идеи, концепции, принципы, методы, процессы, системы, способы, решения технических, организационных или иных задач, открытия, факты, языки программирования. Авторские права распространяются на часть произведения, на его название, если по своему характеру они могут быть признаны самостоятельным результатом творческого труда автора и отвечают установленным требованиям. 1. Переводчику, а также автору иного производного произведения (обработки, экранизации или другого подобного произведения) принадлежат авторские права соответственно на осуществленные перевод и иную переработку другого (оригинального) произведения. Составителю сборника и автору иного составного произведения (антологии, энциклопедии, базы данных, атласа или другого подобного произведения) принадлежат авторские права на осуществленные ими подбор или расположение материалов (составительство). Базой данных является представленная в объективной форме совокупность самостоятельных материалов (статей, расчетов и иных подобных материалов), систематизированных таким образом, чтобы эти материалы могли быть найдены и обработаны с помощью электронной вычислительной машины (ЭВМ). Переводчик, составитель либо иной автор производного или составного произведения осуществляет свои авторские права при условии соблюдения прав авторов произведений, использованных для создания производного или составного произведения.
6
Авторские права переводчика, составителя и иного автора производного или составного произведения охраняются как права на самостоятельные объекты авторских прав независимо от охраны прав авторов произведений, на которых основано производное или составное произведение. Автор произведения, помещенного в сборнике или ином составном произведении, вправе использовать свое произведение независимо от составного произведения, если иное не предусмотрено договором с создателем составного произведения. Авторские права на перевод, сборник, иное производное или составное произведение не препятствуют другим лицам переводить либо перерабатывать то же оригинальное произведение, а также создавать свои составные произведения путем иного подбора или расположения тех же материалов. Издателю энциклопедий, энциклопедических словарей, периодических и продолжающихся сборников научных трудов, журналов и других периодических изданий принадлежит право использования таких изданий. Издатель вправе при любом использовании такого издания указывать свое наименование или требовать его указания. Авторы или иные обладатели исключительных прав на произведения, включенные в такие издания, сохраняют эти права независимо от права издателя или других лиц на использование таких изданий в целом, за исключением случаев, когда эти исключительные права были переданы издателю или другим лицам либо перешли к издателю или другим лицам по иным основаниям, предусмотренным законом. Авторские права на все виды программ для ЭВМ (в том числе на операционные системы и программные комплексы), которые могут быть выражены на любом языке и в любой форме, включая исходный текст и объектный код, охраняются так же, как авторские права на произведения литературы. Программой для ЭВМ является представленная в объективной форме совокупность данных и команд, предназначенных для функционирования ЭВМ и других компьютерных устройств в целях получения определенного результата, включая подготовительные материалы, полученные в ходе разработки программы для ЭВМ, и порождаемые ею аудиовизуальные отображения. Правообладатель в течение срока действия исключительного права на программу для ЭВМ или на базу данных может по своему желанию зарегистрировать такую программу или такую базу данных в федеральном органе исполнительной власти по интеллектуальной собственности.
7
Программы для ЭВМ и базы данных, в которых содержатся сведения, составляющие государственную тайну, государственной регистрации не подлежат. Лицо, подавшее заявку на государственную регистрацию (заявитель), несет ответственность за разглашение сведений о программах для ЭВМ и базах данных, в которых содержатся сведения, составляющие государственную тайну, в соответствии с законодательством Российской Федерации. Заявка на государственную регистрацию программы для ЭВМ или базы данных (заявка на регистрацию) должна относиться к одной программе для ЭВМ или к одной базе данных. Заявка на регистрацию должна содержать: заявление о государственной регистрации программы для ЭВМ или базы данных с указанием правообладателя, а также автора, если он не отказался быть упомянутым в качестве такового, и места жительства или места нахождения каждого из них; депонируемые материалы, идентифицирующие программу для ЭВМ или базу данных, включая реферат; документ, подтверждающий уплату государственной пошлины в установленном размере или наличие оснований для освобождения от уплаты государственной пошлины, либо для уменьшения ее размера, либо для отсрочки ее уплаты. Правила оформления заявки на регистрацию устанавливает федеральный орган исполнительной власти, осуществляющий нормативноправовое регулирование в сфере интеллектуальной собственности. На основании заявки на регистрацию федеральный орган исполнительной власти по интеллектуальной собственности проверяет наличие необходимых документов и материалов, их соответствие предусмотренным требованиям. При положительном результате проверки указанный федеральный орган вносит программу для ЭВМ или базу данных соответственно в Реестр программ для ЭВМ и в Реестр баз данных, выдает заявителю свидетельство о государственной регистрации и публикует сведения о зарегистрированных программе для ЭВМ или базе данных в официальном бюллетене этого органа. По запросу указанного федерального органа либо по собственной инициативе автор или иной правообладатель вправе до публикации сведений в официальном бюллетене дополнять, уточнять и исправлять документы и материалы, содержащиеся в заявке на регистрацию. Порядок государственной регистрации программ для ЭВМ и баз данных, формы свидетельств о государственной регистрации, перечень указываемых в них сведений и перечень сведений, публикуемых в официальном бюллетене федерального органа исполнительной власти по
8
интеллектуальной собственности, устанавливаются федеральным органом исполнительной власти, осуществляющим нормативно-правовое регулирование в сфере интеллектуальной собственности. Договоры об отчуждении исключительного права на зарегистрированные программу для ЭВМ или базу данных и переход исключительного права на такую программу или базу данных к другим лицам без договора подлежат государственной регистрации в федеральном органе исполнительной власти по интеллектуальной собственности. Сведения об изменении обладателя исключительного права вносятся в Реестр программ для ЭВМ или в Реестр баз данных на основании зарегистрированного договора или иного правоустанавливающего документа и публикуются в официальном бюллетене федерального органа исполнительной власти по интеллектуальной собственности. Сведения, внесенные в Реестр программ для ЭВМ или в Реестр баз данных, считаются достоверными, поскольку не доказано иное. Ответственность за достоверность предоставленных для государственной регистрации сведений несет заявитель. Право авторства - право признаваться автором произведения и право автора на имя - право использовать или разрешать использование произведения под своим именем, под вымышленным именем (псевдонимом) или без указания имени, то есть анонимно, неотчуждаемы и непередаваемы, в том числе при передаче другому лицу или переходе к нему исключительного права на произведение и при предоставлении другому лицу права использования произведения. При опубликовании произведения анонимно или под псевдонимом (за исключением случая, когда псевдоним автора не оставляет сомнения в его личности) издатель, имя или наименование которого указано на произведении, при отсутствии доказательств иного считается представителем автора и в этом качестве имеет право защищать права автора и обеспечивать их осуществление. Это положение действует до тех пор, пока автор такого произведения не раскроет свою личность и не заявит о своем авторстве. Не допускается без согласия автора внесение в его произведение изменений, сокращений и дополнений, снабжение произведения при его использовании иллюстрациями, предисловием, послесловием, комментариями или какими бы то ни было пояснениями (право на неприкосновенность произведения). При использовании произведения после смерти автора лицо, обладающее исключительным правом на произведение, вправе разрешить внесение в произведение изменений, сокращений или дополнений при
9
условии, что этим не искажается замысел автора и не нарушается целостность восприятия произведения и это не противоречит воле автора, определенно выраженной им в завещании, письмах, дневниках или иной письменной форме. Извращение, искажение или иное изменение произведения, порочащие честь, достоинство или деловую репутацию автора, равно как и посягательство на такие действия, дают автору право требовать защиты его чести, достоинства или деловой репутации. В этих случаях по требованию заинтересованных лиц допускается защита чести и достоинства автора и после его смерти. Авторство, имя автора и неприкосновенность произведения охраняются бессрочно. Автор вправе в порядке, предусмотренном для назначения исполнителя завещания, указать лицо, на которое он возлагает охрану авторства, имени автора и неприкосновенности произведения после своей смерти. Это лицо осуществляет свои полномочия пожизненно. При отсутствии таких указаний или в случае отказа назначенного автором лица от исполнения соответствующих полномочий, а также после смерти этого лица охрана авторства, имени автора и неприкосновенности произведения осуществляется наследниками автора, их правопреемниками и другими заинтересованными лицами. Автору принадлежит право на обнародование своего произведения, то есть право осуществить действие или дать согласие на осуществление действия, которое впервые делает произведение доступным для всеобщего сведения путем его опубликования, либо любым другим способом. При этом опубликованием (выпуском в свет) является выпуск в обращение экземпляров произведения, представляющих собой копию произведения в любой материальной форме, в количестве, достаточном для удовлетворения разумных потребностей публики исходя из характера произведения. Автор, передавший другому лицу по договору произведение для использования, считается согласившимся на обнародование этого произведения. Произведение, не обнародованное при жизни автора, может быть обнародовано после его смерти лицом, обладающим исключительным правом на произведение, если обнародование не противоречит воле автора произведения, определенно выраженной им в письменной форме (в завещании, письмах, дневниках и тому подобном). Автор имеет право отказаться от ранее принятого решения об обнародовании произведения (право на отзыв) при условии возмещения лицу, которому отчуждено исключительное право на произведение или
10
предоставлено право использования произведения, причиненных таким решением убытков. Если произведение уже обнародовано, автор также обязан публично оповестить о его отзыве. При этом автор вправе изъять из обращения ранее выпущенные экземпляры произведения, возместив причиненные этим убытки. Эти правила не применяются к программам для ЭВМ, к служебным произведениям и к произведениям, вошедшим в сложный объект. Автору произведения или иному правообладателю принадлежит исключительное право использовать произведение в любой форме и любым не противоречащим закону способом (исключительное право на произведение). Правообладатель может распоряжаться исключительным правом на произведение. Использованием произведения независимо от того, совершаются ли соответствующие действия в целях извлечения прибыли или без такой цели, считается, в частности: 1) воспроизведение произведения, то есть изготовление одного и более экземпляра произведения или его части в любой материальной форме, в том числе в форме звуко- или видеозаписи, изготовление в трех измерениях одного и более экземпляра двухмерного произведения и в двух измерениях одного и более экземпляра трехмерного произведения. При этом запись произведения на электронном носителе, в том числе запись в память ЭВМ, также считается воспроизведением, кроме случая, когда такая запись является временной и составляет неотъемлемую и существенную часть технологического процесса, имеющего единственной целью правомерное использование записи или правомерное доведение произведения до всеобщего сведения; 2) распространение произведения путем продажи или иного отчуждения его оригинала или экземпляров; 3) публичный показ произведения, то есть любая демонстрация оригинала или экземпляра произведения непосредственно либо на экране с помощью пленки, диапозитива, телевизионного кадра или иных технических средств, а также демонстрация отдельных кадров аудиовизуального произведения без соблюдения их последовательности непосредственно либо с помощью технических средств в месте, открытом для свободного посещения, или в месте, где присутствует значительное число лиц, не принадлежащих к обычному кругу семьи, независимо от того, воспринимается произведение в месте его демонстрации или в другом месте одновременно с демонстрацией произведения; 4) импорт оригинала или экземпляров произведения в целях распространения; 5) прокат оригинала или экземпляра произведения;
11
6) публичное исполнение произведения, то есть представление произведения в живом исполнении или с помощью технических средств; 7) сообщение в эфир, то есть сообщение произведения для всеобщего, за исключением сообщения по кабелю. При этом под сообщением понимается любое действие, посредством которого произведение становится доступным для слухового и (или) зрительного восприятия независимо от его фактического восприятия публикой. При сообщении произведений в эфир через спутник под сообщением в эфир понимается прием сигналов с наземной станции на спутник и передача сигналов со спутника, посредством которых произведение может быть доведено до всеобщего сведения независимо от его фактического приема публикой. Сообщение кодированных сигналов признается сообщением в эфир, если средства декодирования предоставляются неограниченному кругу лиц организацией эфирного вещания или с ее согласия; 8) сообщение по кабелю, то есть сообщение произведения для всеобщего сведения по радио или телевидению с помощью кабеля, провода, оптического волокна или аналогичных средств (в том числе путем ретрансляции). Сообщение кодированных сигналов признается сообщением по кабелю, если средства декодирования предоставляются неограниченному кругу лиц организацией кабельного вещания или с ее согласия; 9) перевод или другая переработка произведения. При этом под переработкой произведения понимается создание производного. Под переработкой (модификацией) программы для ЭВМ или базы данных понимаются любые их изменения, в том числе перевод такой программы или такой базы данных с одного языка на другой язык, за исключением адаптации, то есть внесения изменений, осуществляемых исключительно в целях функционирования программы для ЭВМ или базы данных на конкретных технических средствах пользователя или под управлением конкретных программ пользователя; 10) практическая реализация; 11) доведение произведения до всеобщего сведения таким образом, что любое лицо может получить доступ к произведению из любого места и в любое время по собственному выбору (доведение до всеобщего сведения). Правообладатель для оповещения о принадлежащем ему исключительном праве на произведение вправе использовать знак охраны авторского права, который помещается на каждом экземпляре произведения и состоит из следующих элементов: латинской буквы "С" в окружности; имени или наименования правообладателя;
12
года первого опубликования произведения. Если оригинал или экземпляры правомерно опубликованного произведения введены в гражданский оборот на территории Российской Федерации путем их продажи или иного отчуждения, дальнейшее распространение оригинала или экземпляров произведения допускается без согласия правообладателя и без выплаты ему вознаграждения. Допускается без согласия автора или иного правообладателя и без выплаты вознаграждения воспроизведение гражданином исключительно в личных целях правомерно обнародованного произведения, за исключением: 1) воспроизведения произведений в форме сооружений; 2) воспроизведения баз данных или их существенных частей; 3) воспроизведения программ для ЭВМ; 4) репродуцирования книг (полностью); 5) видеозаписи аудиовизуального произведения при его публичном исполнении в месте, открытом для свободного посещения, или в месте, где присутствует значительное число лиц, не принадлежащих к обычному кругу семьи; 6) воспроизведения аудиовизуального произведения с помощью профессионального оборудования, не предназначенного для использования в домашних условиях. Допускается без согласия автора или иного правообладателя и без выплаты вознаграждения, но с обязательным указанием имени автора, произведение которого используется, и источника заимствования: 1) цитирование в оригинале и в переводе в научных, полемических, критических или информационных целях правомерно обнародованных произведений в объеме, оправданном целью цитирования, включая воспроизведение отрывков из журнальных статей в форме обзоров печати; 2) использование правомерно обнародованных произведений и отрывков из них в качестве иллюстраций в изданиях, радио- и телепередачах, звуко- и видеозаписях учебного характера в объеме, оправданном поставленной целью; 3) воспроизведение в прессе, сообщение в эфир или по кабелю правомерно опубликованных в журналах, когда такое воспроизведение или сообщение не было специально запрещено автором или иным правообладателем; 4) воспроизведение в прессе, сообщение в эфир или по кабелю публично произнесенных докладов и других аналогичных произведений в объеме, оправданном информационной целью. При этом за авторами таких произведений сохраняется право на их опубликование в сборниках;
13
5) воспроизведение или сообщение для всеобщего сведения в обзорах текущих событий средствами фотографии, кинематографии, путем сообщения в эфир или по кабелю произведений, которые становятся увиденными или услышанными в ходе таких событий, в объеме, оправданном информационной целью; 6) воспроизведение без извлечения прибыли рельефно-точечным шрифтом или другими специальными способами для слепых правомерно опубликованных произведений, кроме произведений, специально созданных для воспроизведения такими способами. В случае, когда библиотека предоставляет экземпляры произведений, правомерно введенные в гражданский оборот, во временное безвозмездное пользование, такое пользование допускается без согласия автора или иного правообладателя и без выплаты вознаграждения. При этом выраженные в цифровой форме экземпляры произведений, предоставляемые библиотеками во временное безвозмездное пользование, в том числе в порядке взаимного использования библиотечных ресурсов, могут предоставляться только в помещениях библиотек при условии исключения возможности создать копии этих произведений в цифровой форме. Допускается без согласия автора или иного правообладателя и без выплаты вознаграждения, но с обязательным указанием имени автора, произведение которого используется, и источника заимствования репродуцирование в единственном экземпляре без извлечения прибыли: 1) правомерно опубликованного произведения - библиотеками и архивами для восстановления, замены утраченных или испорченных экземпляров произведения и для предоставления экземпляров произведения другим библиотекам, утратившим их по каким-либо причинам из своих фондов; 2) отдельных статей и малообъемных произведений, правомерно опубликованных в сборниках, периодических изданиях, коротких отрывков из правомерно опубликованных письменных произведений (с иллюстрациями или без иллюстраций) - библиотеками и архивами по запросам граждан для использования в учебных или научных целях, а также образовательными учреждениями для аудиторных занятий. Под репродуцированием (репрографическим воспроизведением) понимается факсимильное воспроизведение произведения с помощью любых технических средств, осуществляемое не в целях издания. Репродуцирование не включает воспроизведение произведения или хранение его копий в электронной (в том числе в цифровой), оптической или иной машиночитаемой форме, кроме случаев создания с помощью
14
технических средств временных осуществления репродуцирования.
копий,
предназначенных
для
Организация эфирного вещания вправе без согласия автора или иного правообладателя и без выплаты дополнительного вознаграждения делать запись в целях краткосрочного пользования того произведения, в отношении которого эта организация получила право на сообщение в эфир, при условии, что такая запись делается организацией эфирного вещания с помощью ее собственного оборудования и для собственных передач. При этом организация обязана уничтожить такую запись в течение шести месяцев со дня ее изготовления, если более продолжительный срок не согласован с правообладателем или не установлен законом. Такая запись может быть сохранена без согласия правообладателя в государственных или муниципальных архивах, если она носит исключительно документальный характер. Лицо, правомерно владеющее экземпляром программы для ЭВМ или экземпляром базы данных (пользователь), вправе без разрешения автора или иного правообладателя и без выплаты дополнительного вознаграждения: 1) внести в программу для ЭВМ или базу данных изменения исключительно в целях их функционирования на технических средствах пользователя и осуществлять действия, необходимые для функционирования таких программы или базы данных в соответствии с их назначением, в том числе запись и хранение в памяти ЭВМ (одной ЭВМ или одного пользователя сети), а также осуществить исправление явных ошибок, если иное не предусмотрено договором с правообладателем; 2) изготовить копию программы для ЭВМ или базы данных при условии, что эта копия предназначена только для архивных целей или для замены правомерно приобретенного экземпляра в случаях, когда такой экземпляр утерян, уничтожен или стал непригоден для использования. При этом копия программы для ЭВМ или базы данных не может быть использована в иных целях, чем цели, указанные в подпункте 1 настоящего пункта, и должна быть уничтожена, если владение экземпляром таких программы или базы данных перестало быть правомерным. Лицо, правомерно владеющее экземпляром программы для ЭВМ, вправе без согласия правообладателя и без выплаты дополнительного вознаграждения изучать, исследовать или испытывать функционирование такой программы в целях определения идей и принципов, лежащих в
15
основе любого элемента программы для ЭВМ, путем осуществления предусмотренных действий. Лицо, правомерно владеющее экземпляром программы для ЭВМ, вправе без согласия правообладателя и без выплаты дополнительного вознаграждения воспроизвести и преобразовать объектный код в исходный текст (декомпилировать программу для ЭВМ) или поручить иным лицам осуществить эти действия, если они необходимы для достижения способности к взаимодействию независимо разработанной этим лицом программы для ЭВМ с другими программами, которые могут взаимодействовать с декомпилируемой программой, при соблюдении следующих условий: 1) информация, необходимая для достижения способности к взаимодействию, ранее не была доступна этому лицу из других источников; 2) указанные действия осуществляются в отношении только тех частей декомпилируемой программы для ЭВМ, которые необходимы для достижения способности к взаимодействию; 3) информация, полученная в результате декомпилирования, может использоваться лишь для достижения способности к взаимодействию независимо разработанной программы для ЭВМ с другими программами, не может передаваться иным лицам, за исключением случаев, когда это необходимо для достижения способности к взаимодействию независимо разработанной программы для ЭВМ с другими программами, а также не может использоваться для разработки программы для ЭВМ, по своему виду существенно схожей с декомпилируемой программой для ЭВМ, или для осуществления другого действия, нарушающего исключительное право на программу для ЭВМ. Применение положений, предусмотренных настоящей статьей, не должно наносить неоправданный ущерб нормальному использованию программы для ЭВМ или базы данных и не должно ущемлять необоснованным образом законные интересы автора или иного правообладателя. Исключительное право на произведение действует в течение всей жизни автора и семидесяти лет, считая с 1 января года, следующего за годом смерти автора. Исключительное право на произведение, созданное в соавторстве, действует в течение всей жизни автора, пережившего других соавторов, и семидесяти лет, считая с 1 января года, следующего за годом его смерти. На произведение, обнародованное анонимно или под псевдонимом, срок действия исключительного права истекает через семьдесят лет, считая с 1 января года, следующего за годом его правомерного обнародования.
16
Если в течение указанного срока автор произведения, обнародованного анонимно или под псевдонимом, раскроет свою личность или его личность не будет далее оставлять сомнений, исключительное право будет действовать в течение срока, установленного пунктом 1 настоящей статьи. Исключительное право на произведение, обнародованное после смерти автора, действует в течение семидесяти лет после обнародования произведения, считая с 1 января года, следующего за годом его обнародования, при условии, что произведение было обнародовано в течение семидесяти лет после смерти автора. Если автор произведения был репрессирован и посмертно реабилитирован, срок действия исключительного права считается продленным и семьдесят лет исчисляются с 1 января года, следующего за годом реабилитации автора произведения. Если автор работал во время Великой Отечественной войны или участвовал в ней, срок действия исключительного права, установленный настоящей статьей, увеличивается на четыре года. По истечении срока действия исключительного права произведение науки, литературы или искусства, как обнародованное, так и необнародованное, переходит в общественное достояние. Произведение, перешедшее в общественное достояние, может свободно использоваться любым лицом без чьего-либо согласия или разрешения и без выплаты авторского вознаграждения. При этом охраняются авторство, имя автора и неприкосновенность произведения. Перешедшее в общественное достояние необнародованное произведение может быть обнародовано любым лицом, если только обнародование произведения не противоречит воле автора, определенно выраженной им в письменной форме (в завещании, письмах, дневниках и тому подобном). Исключительное право на произведение переходит по наследству. На принадлежащее автору исключительное право на произведение обращение взыскания не допускается. Однако на права требования автора к другим лицам по договорам об отчуждении исключительного права на произведение и по лицензионным договорам, а также на доходы, полученные от использования произведения, может быть обращено взыскание. На исключительное право, принадлежащее не самому автору, а другому лицу, и на право использования произведения, принадлежащее лицензиату, может быть обращено взыскание. Правила абзаца первого настоящего пункта распространяются на наследников автора, их наследников и так далее в пределах срока действия исключительного права.
17
В случае продажи принадлежащего лицензиату права использования произведения с публичных торгов в целях обращения взыскания на это право автору предоставляется преимущественное право его приобретения. По договору об отчуждении исключительного права на произведение автор или иной правообладатель передает или обязуется передать принадлежащее ему исключительное право на произведение в полном объеме приобретателю такого права. По лицензионному договору одна сторона - автор или иной правообладатель (лицензиар) предоставляет либо обязуется предоставить другой стороне (лицензиату) право использования этого произведения в установленных договором пределах. Лицензионный договор заключается в письменной форме. Договор о предоставлении права использования произведения в периодическом печатном издании может быть заключен в устной форме. Заключение лицензионных договоров о предоставлении права использования программы для ЭВМ или базы данных допускается путем заключения каждым пользователем с соответствующим правообладателем договора присоединения, условия которого изложены на приобретаемом экземпляре таких программы или базы данных либо на упаковке этого экземпляра. Начало использования таких программы или базы данных пользователем, как оно определяется этими условиями, означает его согласие на заключение договора. В возмездном лицензионном договоре должен быть указан размер вознаграждения за использование произведения или порядок исчисления такого вознаграждения. В таком договоре может быть предусмотрена выплата лицензиару вознаграждения в форме фиксированных разовых или периодических платежей, процентных отчислений от дохода (выручки) либо в иной форме. Правительство Российской Федерации вправе устанавливать минимальные ставки авторского вознаграждения за отдельные виды использования произведений. По договору о предоставлении права использования произведения, заключенному автором или иным правообладателем с издателем, то есть с лицом, на которое в соответствии с договором возлагается обязанность издать произведение (издательский лицензионный договор), лицензиат обязан начать использование произведения не позднее срока, установленного в договоре. При неисполнении этой обязанности лицензиар вправе отказаться от договора без возмещения лицензиату причиненных таким отказом убытков.
18
В случае отсутствия в договоре конкретного срока начала использования произведения такое использование должно быть начато в срок, обычный для данного вида произведений и способа их использования. Такой договор может быть расторгнут лицензиаром по основаниям и в порядке, которые предусмотрены действующим Кодексом. В случае расторжения издательского лицензионного договора лицензиар вправе требовать выплаты ему вознаграждения, предусмотренного данным договором, в полном размере. По договору авторского заказа одна сторона (автор) обязуется по заказу другой стороны (заказчика) создать обусловленное договором произведение науки на материальном носителе или в иной форме. Материальный носитель произведения передается заказчику в собственность, если соглашением сторон не предусмотрена его передача заказчику во временное пользование. Договор авторского заказа является возмездным, если соглашением сторон не предусмотрено иное. Договором авторского заказа может быть предусмотрено отчуждение заказчику исключительного права на произведение, которое должно быть создано автором, или предоставление заказчику права использования этого произведения в установленных договором пределах. В случае, когда договор авторского заказа предусматривает отчуждение заказчику исключительного права на произведение, которое должно быть создано автором, к такому договору соответственно применяются правила действующего Кодекса о договоре об отчуждении исключительного права, если из существа договора не вытекает иное. Если договор авторского заказа заключен с условием о предоставлении заказчику права использования произведения в установленных договором пределах, к такому договору соответственно применяются положения, предусмотренные Кодексом. Произведение, создание которого предусмотрено договором авторского заказа, должно быть передано заказчику в срок, установленный договором. Договор, который не предусматривает и не позволяет определить срок его исполнения, не считается заключенным. В случае, когда срок исполнения договора авторского заказа наступил, автору при необходимости и при наличии уважительных причин для завершения создания произведения предоставляется дополнительный льготный срок продолжительностью в одну четвертую часть срока, установленного для исполнения договора, если соглашением сторон не предусмотрен более длительный льготный срок.
19
По истечении льготного срока, предоставленного автору, заказчик вправе в одностороннем порядке отказаться от договора авторского заказа. Заказчик также вправе отказаться от договора авторского заказа непосредственно по окончании срока, установленного договором для его исполнения, если договор к этому времени не исполнен, а из его условий явно вытекает, что при нарушении срока исполнения договора заказчик утрачивает интерес к договору. Ответственность автора по договору об отчуждении исключительного права на произведение и по лицензионному договору ограничена суммой реального ущерба, причиненного другой стороне, если договором не предусмотрен меньший размер ответственности автора. В случае неисполнения или ненадлежащего исполнения договора авторского заказа, за которое автор несет ответственность, автор обязан возвратить заказчику аванс, а также уплатить ему неустойку, если она предусмотрена договором. При этом общий размер указанных выплат ограничен суммой реального ущерба, причиненного заказчику. При отчуждении автором оригинала произведения (рукописи), в том числе при отчуждении оригинала произведения по договору авторского заказа, исключительное право на произведение сохраняется за автором, если договором не предусмотрено иное. В случае, когда исключительное право на произведение не перешло к приобретателю его оригинала, приобретатель вправе без согласия автора и без выплаты ему вознаграждения демонстрировать приобретенный в собственность оригинал произведения и воспроизводить его в каталогах выставок и в изданиях, посвященных его коллекции, а также передавать оригинал этого произведения для демонстрации на выставках, организуемых другими лицами. При отчуждении оригинала произведения его собственником, обладающим исключительным правом на произведение, но не являющимся автором произведения, исключительное право на произведение переходит к приобретателю оригинала произведения, если договором не предусмотрено иное. Правила, относящиеся к автору произведения, распространяются также на наследников автора, их наследников и так далее в пределах срока действия исключительного права на произведение. Автор произведения изобразительного искусства вправе требовать от собственника оригинала произведения предоставления возможности осуществлять право на воспроизведение своего произведения (право доступа). При этом от собственника оригинала произведения нельзя требовать доставки произведения автору.
20
Авторское, созданное в пределах установленных для работника (автора) трудовых обязанностей (служебное произведение), принадлежат автору. Исключительное право на служебное произведение принадлежит работодателю, если трудовым или иным договором между работодателем и автором не предусмотрено иное. Если работодатель в течение трех лет со дня, когда служебное произведение было предоставлено в его распоряжение, не начнет использование этого произведения, не передаст исключительное право на него другому лицу или не сообщит автору о сохранении произведения в тайне, исключительное право на служебное произведение принадлежит автору. Если работодатель в срок, предусмотренный в абзаце втором настоящего пункта, начнет использование служебного произведения или передаст исключительное право другому лицу, автор имеет право на вознаграждение. Автор приобретает указанное право на вознаграждение и в случае, когда работодатель принял решение о сохранении служебного произведения в тайне и по этой причине не начал использование этого произведения в указанный срок. Размер вознаграждения, условия и порядок его выплаты работодателем определяются договором между ним и работником, а в случае спора - судом. В случае, когда исключительное право на служебное произведение принадлежит автору, работодатель вправе использовать такое произведение способами, обусловленными целью служебного задания, и в вытекающих из задания пределах, а также обнародовать такое произведение, если договором между ним и работником не предусмотрено иное. При этом право автора использовать служебное произведение способом, не обусловленным целью служебного задания, а также хотя бы и способом, обусловленным целью задания, но за пределами, вытекающими из задания работодателя, не ограничивается. Работодатель может при использовании служебного произведения указывать свое имя или наименование либо требовать такого указания. В случае, когда программа для ЭВМ или база данных создана по договору, предметом которого было ее создание (по заказу), исключительное право на такую программу или такую базу данных принадлежит заказчику, если договором между подрядчиком (исполнителем) и заказчиком не предусмотрено иное. В случае, когда исключительное право на программу для ЭВМ или базу данных принадлежит заказчику, подрядчик (исполнитель) вправе, поскольку договором не предусмотрено иное, использовать такую программу или такую базу данных для собственных нужд на условиях
21
безвозмездной простой (неисключительной) лицензии в течение всего срока действия исключительного права. В случае, когда в соответствии с договором между подрядчиком (исполнителем) и заказчиком исключительное право на программу для ЭВМ или базу данных принадлежит подрядчику (исполнителю), заказчик вправе использовать такую программу или такую базу данных для собственных нужд на условиях безвозмездной простой (неисключительной) лицензии в течение всего срока действия исключительного права. Автор созданных по заказу программы для ЭВМ или базы данных, которому не принадлежит исключительное право на такую программу или такую базу данных, имеет право на вознаграждение. Если программа для ЭВМ или база данных создана при выполнении договора подряда или договора на выполнение научноисследовательских, опытно-конструкторских или технологических работ, которые прямо не предусматривали ее создание, исключительное право на такую программу или такую базу данных принадлежит подрядчику (исполнителю), если договором между ним и заказчиком не предусмотрено иное. В этом случае заказчик вправе, если договором не предусмотрено иное, использовать созданные таким образом программу или базу данных в целях, для достижения которых был заключен соответствующий договор, на условиях простой (неисключительной) лицензии в течение всего срока действия исключительного права без выплаты за это использование дополнительного вознаграждения. При передаче подрядчиком (исполнителем) исключительного права на программу для ЭВМ или базу данных другому лицу заказчик сохраняет право использования программы или базы данных. В случае, когда в соответствии с договором между подрядчиком (исполнителем) и заказчиком исключительное право на программу для ЭВМ или базу данных передано заказчику либо указанному им третьему лицу, подрядчик (исполнитель) вправе использовать созданные им программу или базу данных для собственных нужд на условиях безвозмездной простой (неисключительной) лицензии в течение всего срока действия исключительного права, если договором не предусмотрено иное. Автор программы для ЭВМ или базы данных, которому не принадлежит исключительное право на такую программу или такую базу данных, имеет право на вознаграждение.
22
Исключительное право на произведение науки, созданное по государственному или муниципальному контракту для государственных или муниципальных нужд, принадлежит исполнителю, являющемуся автором либо иным выполняющим государственный или муниципальный контракт лицом, если государственным или муниципальным контрактом не предусмотрено, что это право принадлежит Российской Федерации, субъекту Российской Федерации или муниципальному образованию, от имени которых выступает государственный или муниципальный заказчик, либо совместно исполнителю и Российской Федерации, исполнителю и субъекту Российской Федерации или исполнителю и муниципальному образованию. Если в соответствии с государственным или муниципальным контрактом исключительное право на произведение науки, литературы или искусства принадлежит Российской Федерации, субъекту Российской Федерации или муниципальному образованию, исполнитель обязан путем заключения соответствующих договоров со своими работниками и третьими лицами приобрести все права или обеспечить их приобретение для передачи соответственно Российской Федерации, субъекту Российской Федерации и муниципальному образованию. При этом исполнитель имеет право на возмещение затрат, понесенных им в связи с приобретением соответствующих прав у третьих лиц. Если исключительное право на произведение науки, литературы или искусства, созданное по государственному или муниципальному контракту для государственных или муниципальных нужд, принадлежит не Российской Федерации, не субъекту Российской Федерации или не муниципальному образованию, правообладатель по требованию государственного или муниципального заказчика обязан предоставить указанному им лицу безвозмездную простую (неисключительную) лицензию на использование соответствующего произведения науки, литературы или искусства для государственных или муниципальных нужд. Если исключительное право на произведение науки, литературы или искусства, созданное по государственному или муниципальному контракту для государственных или муниципальных нужд, принадлежит совместно исполнителю и Российской Федерации, исполнителю и субъекту Российской Федерации или исполнителю и муниципальному образованию, государственный или муниципальный заказчик вправе предоставить безвозмездную простую (неисключительную) лицензию на использование такого произведения науки, литературы или искусства для государственных или муниципальных нужд, уведомив об этом исполнителя.
23
Работник, исключительное право которого перешло к исполнителю, имеет право на вознаграждение. Правила настоящей статьи также применяются к программам для ЭВМ и базам данных, создание которых не было предусмотрено государственным или муниципальным контрактом для государственных или муниципальных нужд, но которые были созданы при выполнении такого контракта. Техническими средствами защиты авторских прав признаются любые технологии, технические устройства или их компоненты, контролирующие доступ к произведению, предотвращающие либо ограничивающие осуществление действий, которые не разрешены автором или иным правообладателем в отношении произведения. В отношении произведений не допускается: 1) осуществление без разрешения автора или иного правообладателя действий, направленных на то, чтобы устранить ограничения использования произведения, установленные путем применения технических средств защиты авторских прав; 2) изготовление, распространение, сдача в прокат, предоставление во временное безвозмездное пользование, импорт, реклама любой технологии, любого технического устройства или их компонентов, использование таких технических средств в целях получения прибыли либо оказание соответствующих услуг, если в результате таких действий становится невозможным использование технических средств защиты авторских прав либо эти технические средства не смогут обеспечить надлежащую защиту указанных прав. В случае нарушения предусмотренных положений, автор или иной правообладатель вправе требовать по своему выбору от нарушителя возмещения убытков или выплаты компенсации, кроме случаев, когда разрешено использование произведения без согласия автора или иного правообладателя. Информацией об авторском праве признается любая информация, которая идентифицирует произведение, автора или иного правообладателя, либо информация об условиях использования произведения, которая содержится на оригинале или экземпляре произведения, приложена к нему или появляется в связи с сообщением в эфир или по кабелю либо доведением такого произведения до всеобщего сведения, а также любые цифры и коды, в которых содержится такая информация. В отношении произведений не допускается: 1) удаление или изменение без разрешения автора или иного правообладателя информации об авторском праве;
24
2) воспроизведение, распространение, импорт в целях распространения, публичное исполнение, сообщение в эфир или по кабелю, доведение до всеобщего сведения произведений, в отношении которых без разрешения автора или иного правообладателя была удалена или изменена информация об авторском праве. В случае нарушения предусмотренных положений, автор или иной правообладатель вправе требовать по своему выбору от нарушителя возмещения убытков или выплаты компенсации в соответствии Кодексом. В случаях нарушения исключительного права на произведение автор или иной правообладатель наряду с использованием других применимых способов защиты и мер ответственности вправе требовать по своему выбору от нарушителя вместо возмещения убытков выплаты компенсации: в размере от десяти тысяч рублей до пяти миллионов рублей, определяемом по усмотрению суда; в двукратном размере стоимости экземпляров произведения или в двукратном размере стоимости права использования произведения, определяемой исходя из цены, которая при сравнимых обстоятельствах обычно взимается за правомерное использование произведения. Суд может запретить ответчику или лицу, в отношении которого имеются достаточные основания полагать, что оно является нарушителем авторских прав, совершать определенные действия (изготовление, воспроизведение, продажу, сдачу в прокат, импорт либо иное предусмотренное Кодексом использование, а также транспортировку, хранение или владение) в целях введения в гражданский оборот экземпляров произведения, в отношении которых предполагается, что они являются контрафактными. Суд может наложить арест на все экземпляры произведения, в отношении которых предполагается, что они являются контрафактными, а также на материалы и оборудование, используемые или предназначенные для их изготовления или воспроизведения. При наличии достаточных данных о нарушении авторских прав органы дознания или следствия обязаны принять меры для розыска и наложения ареста на экземпляры произведения, в отношении которых предполагается, что они являются контрафактными, а также на материалы и оборудование, используемые или предназначенные для изготовления или воспроизведения указанных экземпляров произведения, включая в необходимых случаях меры по их изъятию и передаче на ответственное хранение.
25
ПРИМЕРЫ ИНТЕЛЛЕКТУАЛЬНЫХ РАЗРАБОТОК АВТОРА Развитие науки и техники возможно на основе теоретических и экспериментальных исследований, анализа полученных экспериментальных данных, систематизации результатов исследований, прогнозирования улучшения процессов и устройств. Значительная эффективность может быть достигнута при применении математического моделирования. Выполнены разработки математического моделирования при планировании экспериментов на двух, трех, четырех, пяти уровнях факторов и при неодинаковом количестве уровней первого и второго факторов, а также многофакторного моделирования. Преимуществами предложенных методик математического моделирования являются оригинальная разработка ортогонализации матриц, вывод формул для расчета коэффициентов регрессии, дисперсий в определении коэффициентов регрессии, буквенное обозначение показателей степени факторов в уравнениях регрессии и возможность изменять величины показателей степени факторов, добиваясь требуемой точности математических моделей. При математическом моделировании используются действительные величины факторов и показателей процесса. Уровни факторов могут быть ассиметричными и симметричными, а математические зависимости - нелинейными или, в частных случаях, линейными. Разработаны на языке Бейсик компьютерные программы математического моделирования, имеющие обозначения VL0, VN0, VN3, VN4, VN5, VN6, VN7, VN8, VN9, WN2, WN3, WN4, WN5, WN6, WN7, WN8, WN9. Эти компьютерные программы в пакете зарегистрированы в отраслевом фонде алгоритмов и программ Государственного координационного центра информационных технологий Федерального агентства по образованию, свидетельство об отраслевой регистрации разработок № 6894. На комплексную разработку «Математическое моделирование в литейном производстве» получено свидетельство об отраслевой регистрации № 7223. В опубликованных работах показано, как выполняется ортогонализация матриц, построение планов проведения экспериментов, как рассчитываются коэффициенты ортогонализации, коэффициенты регрессии, дисперсии в определении коэффициентов регрессии. Построение схем зависимостей показателей процесса от факторов позволило наглядно показать связь координат точек графиков с планами проведения экспериментов (координаты каждой точки графиков являются, соответственно, строкой плана).
26
В большинстве компьютерных программ математического моделирования объединены несколько программ. Так, в комплексной программе VL0 объединены пять программ для случаев планирования 21 (Х = 2), 22 (Х=4), 23 (Х=8), 24 (Х=16), 25 (Х=32). В комплектную программу VN0 входят десять программ для планирования 31 (Х=3), 41 (Х= 4), 51 (Х=5), 32 (Х=9), 3·4 (Х=12), 3·5 (Х=15), 42 (Х=16), 4·5 (Х=20), 52 (Х=25), 33 (Х=27). В зависимости от того, какая величина Х будет введена, начнет работать соответствующая значению Х программа. Программы составлены так, что достигается высокая точность расчетов, осуществляется проверка расчетов. В первой части каждой программы выполняется аппроксимация, затем выявляется математическая модель, далее можно выполнять расчеты по модели, проверять точность модели, вычислять показатели по математической модели с использованием циклов, строить графики зависимостей показателей от факторов. После выявления математической модели необходимо проводить ее анализ, что делать трудно с увеличением количества факторов, количества уровней факторов, усложнением математической модели. Потребовалась разработка системного анализа результатов расчетов по математическим моделям. Оригинальная разработка такого анализа выполнена применительно к работе «Математическое моделирование в литейном производстве» [9] и программам VL0, VN0. Используя дополнения (подпрограммы) к программе VN0, можно ввести подпрограммы, позволяющие выполнять системный анализ результатов расчетов по математическим моделям, в компьютерные программы VN3, VN4, VN5, VN6, VN7, VN8, VN9, WN2, WN3, WN4, WN5, WN6, WN7, WN8, WN9.После дополнения подпрограммами системного анализа результатов расчетов по математическим моделям указанные выше компьютерные программы будут иметь наименование NV0, NV3, NV4, NV5, NV6, NV7, NV8, NV9, NW2, NW3, NW4, NW5, NW6, NW7, NW8, NW9. Такая перестановка букв в наименованиях программ позволяет легко отличать ранее разработанные компьютерные программы от соответствующих им, но дополненных подпрограмм системного анализа результатов расчетов по математическим моделям. Из программы VL0 можно получить две программы LV0, LV1. Программы математического моделирования с языка Бейсик переложены на язык Турбо Паскаль. Эти программы имеют обозначения LV1, TNV1, TNV3, TNV4, TNV5, NW3, NW0, NW5, NW6, W6. Для переработки использованы компьютерные программы tpgl1_1, tpgl1_2 (двухмодульное переложение с языка Бейсик программы GGL3) и
27
программы tpg3_1, tpg3_2, tpg3_3 (трехмодульное переложение с языка Бейсик программы GGN3).
28
ПРОГРАММЫ МАТЕМАТИЧЕСКОГО МОДЕЛИРОВАНИЯ НА ЯЗЫКЕ ТУРБО ПАСКАЛЬ
29
Программа LV1(два модуля tpgl3, 1-й вариант, _Х=2_, _Х=4_, _Х=8_, Х=16, «система» после «адекватно»)
program tpgl1_1; uses tpgl1_2; label 1,2,3,4,5; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значе'); writeln(F0,'ние │'); write(F0,'│ J ├──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │'); writeln(F0,' L(J) │ Z(J) │'); end; if PR=76 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значение '); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ Z(J) │'); end; if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end;
writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; if PR=76 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',K[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end; end;{OUT_F_H_L} procedure GB2820; begin writeln(F0,'Математическая модель'); if X=2 then begin writeln(F0,'X=2.Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J),'); end; if X=4 then begin writeln(F0,'X=4.Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J),'); end; if X=8 then begin writeln(F0,'X=8.Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+');
31
writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J),'); end; if X=16 then begin writeln(F0,'X=16.Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J),'); end; if (X=2)or(X=4)or(X=8)or(X=16) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1,'+',V1); writeln(F0,'Обозначение:F(J)- 1-ый фактор '); end; if (X=4)or(X=8)or(X=16) then begin writeln(F0,'P(J)=H(J)^',J2,'+',V2); writeln(F0,'Обозначение:H(J)- 2-ой фактор'); end; if (X=8)or(X=16) then begin writeln(F0,'U(J)=L(J)^',J3,'+',V3); writeln(F0,'Обозначение:L(J)- 3-ий фактор'); end; if (X=16) then begin writeln(F0,'Q(J)=K(J)^',J4,'+',V4); writeln(F0,'Обозначение:K(J)- 4-ый фактор'); end; end;{GB2820} procedure GB7000; label 1; begin repeat writeln('Вычисления показателей Z(K5)'); writeln(' по математической модели'); writeln(' с ипользованием циклов'); writeln('vvod X'); readln(X); writeln('X=',X); writeln(F0,'Вычисления показателей Z(K5)'); writeln(F0,' по математической модели'); writeln(F0,' с ипользованием циклов'); writeln(F0,'X=',X); case X of 2: I0:=73; 4: I0:=74; 8: I0:=75; 16: I0:=76; end;
32
if I0=73 then begin K5:=0; F3:=0; F4:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=0; F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end; GB2490; GB2540; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=74 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=0; F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=0; H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); end; GB2490; GB2500; GB2550; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]);
33
OUT_F_H_L(I0); end;{if} if I0=75 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=0; F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=0; H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=0; L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); end; GB2490; GB2500; GB2510; GB2570; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=76 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln('X-количество значений 1,2,3,4-го фактора'); writeln(F0,'F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln(F0,'X-количество значений 1,2,3,4-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4);
34
writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); for K5:=1 to X do begin F[K5]:=0; F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=0; H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=0; L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=0; K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); end; GB2490; GB2500;GB2510; GB2520; GB2600; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=77 then writeln('Выявление MAX Z(K5) и MIN Z(K5)'); K8:=0; K8:=Z[1]; for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; begin writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); end; for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end;
35
J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000} procedure tablF9; begin writeln('Значения F7 для 5% уровня знач-ти'); writeln('┌───┬───────────────────────────┐'); writeln('│ │ F9 │'); writeln('│F8 ├────┬─────┬─────┬─────┬────┤'); writeln('│ │ 1 │ 3 │ 7 │ 15 │ 31 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 2 │19.0│19.16│19.36│19.42│9.46│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 3 │9.55│ 9.28│ 8.88│ 8.71│8.62│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 4 │6.94│ 6.59│ 6.09│ 5.87│5.74│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 5 │5.79│ 5.41│ 4.88│ 4.64│4.5 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 6 │5.14│ 4.76│ 4.21│ 3.96│3.81│'); writeln('└───┴────┴─────┴─────┴─────┴────┘'); end; procedure OUT_Z_B; begin writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); writeln('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {========================Основная программа=======================} begin
36
1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из двух'); writeln(' файлов tpgl1_1,tpl1_2(lv1_1,lv1_2). Математическое'); writeln(' моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программ GGL3, LV1.'); writeln(' Разработка Черного А.А.'); writeln(' Autor Chernyy Anatoly Alekseevech'); writeln('Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,'Выполнение программы математического моделирования'); writeln(F0,' tpgl1_1 (lv1_1). (Программа на языке Турбо-Паскаль).'); writeln('_X=2_, _X=4_ ,_X=8_ ,X=16'); writeln(F0,' Autor Chernyy Anatoly Alekseevech'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; case X of 2: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); end; 4: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); end; 8: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3);
37
writeln('V3=',V3); end; 16: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24; GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); end; 0: goto 2; else goto 2; end;{case} if (X=2)or(X=4)or(X=8)or(X=16) then begin F[1]:=A1; F[2]:=B1; end; if (X=4)or(X=8)or(X=16) then begin H[1]:=A2; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; end; if (X=8)or(X=16) then begin L[1]:=A3; L[2]:=A3; L[3]:=A3; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; end; if (X=16) then begin K[1]:=A4; K[2]:=A4; K[3]:=A4; K[4]:=A4; K[5]:=A4; K[6]:=A4; K[7]:=A4; K[8]:=A4; F[9]:=A1; H[9]:=A2; L[9]:=A3; K[9]:=B4; F[10]:=B1; H[10]:=A2; L[10]:=A3; K[10]:=B4; F[11]:=A1; H[11]:=B2; L[11]:=A3; K[11]:=B4; F[12]:=B1; H[12]:=B2; L[12]:=A3; K[12]:=B4; F[13]:=A1; H[13]:=A2; L[13]:=B3; K[13]:=B4; F[14]:=B1; H[14]:=A2; L[14]:=B3; K[14]:=B4; F[15]:=A1; H[15]:=B2; L[15]:=B3; K[15]:=B4; F[16]:=B1; H[16]:=B2; L[16]:=B3; K[16]:=B4; end; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y[J]');
38
writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 2: GB2490; 4: begin GB2490; GB2500; end; 8: begin GB2490; GB2500; GB2510; end; 16: begin GB2490; GB2500; GB2510; GB2520; end; end;{case} GB780; case X of 4: GB810; 8: begin GB810; GB850; end; 16: begin GB810; GB850; GB940; end; end;{case} writeln(' B(J) до анализа'); writeln(F0,' B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1;
39
if I0=20 then goto 2; if I0=5 then goto 5; if I0=30 then goto 3; if I0=25 then begin GB2820; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'N0-количество опытов на среднем уровне факторов'); writeln(F0,'N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'Ввод G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; writeln(F0,'S0=',S0); for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'U9-дисперсия опытов =',U9); end; if not(I0=5) then begin writeln(' Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │');
40
writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'T-критерий T0=',T0); writeln(' B(J) после анализа'); writeln(F0,' B(J) после анализа'); for J:=1 to X do begin if T[J]F7 then begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; if X=2 then begin writeln(F0,'X=2. System, 1.1 - 1.2, finish 1.2.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','B1=',B1,'Z(2)=',Z[2]); end; if X=4 then begin writeln(F0,'X=4. System, 1.1 - 4.2, finish 4.2.'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'2.2.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'3.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'3.2.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'4.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'4.2.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); end; if X=8 then begin writeln(F0,'X=8. System, 1.1 - 12.2, finish 12.2.'); writeln(F0,'1.1.','A2=',A2,'A3=',A3,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'A3=',A3,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','A2=',A2,'B3=',B3,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'2.2.','A2=',A2,'B3=',B3,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'3.1.','B2=',B2,'A3=',A3,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'3.2.','B2=',B2,'A3=',A3,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'4.1.','B2=',B2,'B3=',B3,'A1=',A1,'Z(7)=',Z[7]); writeln(F0,'4.2.','B2=',B2,'B3=',B3,'B1=',B1,'Z(8)=',Z[8]); writeln(F0,'5.1.','A1=',A1,'A3=',A3,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'5.2.','A1=',A1,'A3=',A3,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'6.1.','A1=',A1,'B3=',B3,'A2=',A2,'Z(5)=',Z[5]); writeln(F0,'6.2.','A1=',A1,'B3=',B3,'B2=',B2,'Z(7)=',Z[7]); writeln(F0,'7.1.','B1=',B1,'A3=',A3,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'7.2.','B1=',B1,'A3=',A3,'B2=',B2,'Z(4)=',Z[4]); writeln(F0,'8.1.','B1=',B1,'B3=',B3,'A2=',A2,'Z(6)=',Z[6]); writeln(F0,'8.2.','B1=',B1,'B3=',B3,'B2=',B2,'Z(8)=',Z[8]); writeln(F0,'9.1.','A1=',A1,'A2=',A2,'A3=',A3,'Z(1)=',Z[1]); writeln(F0,'9.2.','A1=',A1,'A2=',A2,'B3=',B3,'Z(5)=',Z[5]); writeln(F0,'10.1.','A1=',A1,'B2=',B2,'A3=',A3,'Z(3)=',Z[3]); writeln(F0,'10.2.','A1=',A1,'B2=',B2,'B3=',B3,'Z(7)=',Z[7]); writeln(F0,'11.1.','B1=',B1,'A2=',A2,'A3=',A3,'Z(2)=',Z[2]); writeln(F0,'11.2.','B1=',B1,'A2=',A2,'B3=',B3,'Z(6)=',Z[6]); writeln(F0,'12.1.','B1=',B1,'B2=',B2,'A3=',A3,'Z(4)=',Z[4]); writeln(F0,'12.2.','B1=',B1,'B2=',B2,'B3=',B3,'Z(8)=',Z[8]); end;
42
case X of 2: OUT_F_H_L(73); 4: OUT_F_H_L(74); 8: OUT_F_H_L(75); 16: OUT_F_H_L(76); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB2820; goto 2; end; if I0=22 then begin GB7000; goto 5; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'Результаты расчетов по модели'); if X=2 then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); GB2490; GB2540; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(73); end; if X=4 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,')'); readln(F[S],H[S]); GB2490; GB2500; GB2550; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(74);
43
end; if X=8 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; L[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2570; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(75); end; if X=16 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; K[S]:=0; L[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,') K(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2520; GB2600; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(76); end; 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if (I0=11) then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end.{Конец программы} unit tpgl1_2; Interface type artp=array[1..50] of real; var
44
J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6,Z2,Z3,Z4,Z5:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2,V4,V5,M3,M4:real; A4,B4,A5,B5,J4,T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0:TEXT; grMode: Integer; function ste(Q,A:real):real; procedure VVOD21; procedure VVOD22; procedure VVOD23; procedure VVOD24; procedure VVOD25; procedure GB780; procedure GB810; procedure GB850; procedure GB940; procedure GB2480(A,B,N:real; var V0:real); procedure GB2490; procedure GB2500; procedure GB2510; procedure GB2520; procedure GB2540; procedure GB2550; procedure GB2570; procedure GB2600; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then exit else begin if Q=0 then A:=1E-20; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure VVOD21; begin writeln('Ввод A1 B1 J1'); readln(A1,B1,J1); writeln(F0,'A1=',A1,' B1=',B1); writeln(F0,'J1=',J1); end; procedure VVOD22; begin writeln('Ввод A2 B2 J2'); readln(A2,B2,J2); writeln(F0,'A2=',A2,' B2=',B2); writeln(F0,'J2=',J2); end; procedure VVOD23; begin writeln('Ввод A3 B3 J3'); readln(A3,B3,J3); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD24; begin writeln('Ввод A4 B4 J4'); readln(A4,B4,J4);
45
writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD25; begin writeln('Ввод A5 B5 J5'); readln(A5,B5,J5); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure GB780; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; end; procedure GB810; begin SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[3]:=O[3]+P[J]*P[J]; end; B[3]:=SS/O[3]; SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[4]:=O[4]+(I[J]*P[J])*(I[J]*P[J]); end; B[4]:=SS/O[4]; end;{GB810} procedure GB850; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[5]:=O[5]+U[J]*U[J]; end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J];
46
O[6]:=O[6]+(I[J]*U[J])*(I[J]*U[J]); end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[7]:=O[7]+(P[J]*U[J])*(P[J]*U[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[8]:=O[8]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[8]:=SS/O[8]; end;{GB850} procedure GB940; begin SS:=0; O[9]:=0; for j:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[9]:=O[9]+Q[J]*Q[J]; end; B[9]:=SS/O[9]; SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[10]:=O[10]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*Y[J]; O[11]:=O[11]+(P[J]*Q[J])*(P[J]*Q[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Q[J]*Y[J]; O[12]:=O[12]+(I[J]*P[J]*Q[J])*(I[J]*P[J]*Q[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[13]:=O[13]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do
47
begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[14]:=O[14]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*Y[J]; O[15]:=O[15]+(P[J]*U[J]*Q[J])*(P[J]*U[J]*Q[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*Y[J]; O[16]:=O[16]+(I[J]*P[J]*U[J]*Q[J])*(I[J]*P[J]*U[J]*Q[J]); end; B[16]:=SS/O[16]; end;{GB940} procedure GB2480(A,B,N:real; var V0:real); begin V0:=-(ste(A,N)+ste(B,N))/2; write('Коэффициент ортогонализации '); write(F0,'Коэффициент ортогонализации '); end;{GB2480} procedure GB2490; begin for J:=1 to X do I[J]:=ste(F[J],J1)+V1; end;{GB2490} procedure GB2500; begin for J:=1 to X do P[J]:=ste(H[J],J2)+V2; end;{GB2500} procedure GB2510; begin for J:=1 to X do U[J]:=ste(L[J],J3)+V3; end;{GB2510} procedure GB2520; begin for J:=1 to X do Q[J]:=ste(K[J],J4)+V4; end;{GB2520} procedure GB2540; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]; end;{GB2540} procedure GB2550; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; end;{GB2550} procedure GB2570;
48
begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; Z[J]:=N3+N4+B[8]*I[J]*P[J]*U[J]; end; end;{GB2570} procedure GB2600; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; Z[J]:=N3+N4+N5+N6+N7+B[16]*I[J]*P[J]*U[J]*Q[J]; end; end;{GB2600} begin end.
49
Программа TNV1(два модуля tpgl3, 2-ой вариант _Х=2_, _Х=4_, _Х=8_, Х=16, «система» до «модели»)
program tpgl1_1; uses tpgl1_2; label 1,2,3,4,5; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значе'); writeln(F0,'ние │'); write(F0,'│ J ├──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │'); writeln(F0,' L(J) │ Z(J) │'); end; if PR=76 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значение '); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ Z(J) │'); end; if PR=77 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'────────────────────────────────┐'); write(F0,'│ │ Зна'); writeln(F0,'чение │'); write(F0,'│ J ├──────────┬──────────┬─────────'); writeln(F0,'─┬──────────┬──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │');
50
writeln(F0,' K(J) │ M(J) │ Z(J) │'); end; if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; if PR=76 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',K[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end; if PR=77 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼────────'); writeln(F0,'──┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); write(F0,L[J]:10,'│',K[J]:10,'│',M[J]:10,'│'); writeln(F0,Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴──────────┴');
51
writeln(F0,'──────────┴──────────┴──────────┘'); end; end;{OUT_F_H_L} procedure GB2820; begin writeln(F0,'System graphic Z(J) for Excel.X=2,X=4,X=8'); writeln(F0,'Математическая модель'); if X=2 then begin writeln('X=2. System'); writeln('1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'X=2. System'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','B1=',B1,'Z(2)=',Z[2]); writeln('X=2. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J),'); writeln(F0,'X=2. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J),'); end; if X=4 then begin writeln('X=4. System'); writeln('1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'X=4. System'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'2.2.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'3.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'3.2.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'4.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'4.2.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); writeln('X=4. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln('+',B[4],'*I(J)*P(J),'); writeln(F0,'X=4. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J),'); end; if X=8 then begin writeln('X=8. System'); writeln('1.1.','A2=',A2,'A3=',A3,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'X=8. System'); writeln(F0,'1.1.','A2=',A2,'A3=',A3,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'A3=',A3,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','A2=',A2,'B3=',B3,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'2.2.','A2=',A2,'B3=',B3,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'3.1.','B2=',B2,'A3=',A3,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'3.2.','B2=',B2,'A3=',A3,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'4.1.','B2=',B2,'B3=',B3,'A1=',A1,'Z(7)=',Z[7]); writeln(F0,'4.2.','B2=',B2,'B3=',B3,'B1=',B1,'Z(8)=',Z[8]); writeln(F0,'5.1.','A1=',A1,'A3=',A3,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'5.2.','A1=',A1,'A3=',A3,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'6.1.','A1=',A1,'B3=',B3,'A2=',A2,'Z(5)=',Z[5]); writeln(F0,'6.2.','A1=',A1,'B3=',B3,'B2=',B2,'Z(7)=',Z[7]); writeln(F0,'7.1.','B1=',B1,'A3=',A3,'A2=',A2,'Z(2)=',Z[2]);
52
writeln(F0,'7.2.','B1=',B1,'A3=',A3,'B2=',B2,'Z(4)=',Z[4]); writeln(F0,'8.1.','B1=',B1,'B3=',B3,'A2=',A2,'Z(6)=',Z[6]); writeln(F0,'8.2.','B1=',B1,'B3=',B3,'B2=',B2,'Z(8)=',Z[8]); writeln(F0,'9.1.','A1=',A1,'A2=',A2,'A3=',A3,'Z(1)=',Z[1]); writeln(F0,'9.2.','A1=',A1,'A2=',A2,'B3=',B3,'Z(5)=',Z[5]); writeln(F0,'10.1.','A1=',A1,'B2=',B2,'A3=',A3,'Z(3)=',Z[3]); writeln(F0,'10.2.','A1=',A1,'B2=',B2,'B3=',B3,'Z(7)=',Z[7]); writeln(F0,'11.1.','B1=',B1,'A2=',A2,'A3=',A3,'Z(2)=',Z[2]); writeln(F0,'11.2.','B1=',B1,'A2=',A2,'B3=',B3,'Z(6)=',Z[6]); writeln(F0,'12.1.','B1=',B1,'B2=',B2,'A3=',A3,'Z(4)=',Z[4]); writeln(F0,'12.2.','B1=',B1,'B2=',B2,'B3=',B3,'Z(8)=',Z[8]); writeln('X=8. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'X=8. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J),'); end; if X=16 then begin writeln('X=16. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'X=16.Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J),'); end; if X=32 then begin writeln('X=32. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'X=32. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J)+',B[17],'*V(J)+'); writeln(F0,'+',B[18],'*I(J)*V(J)+',B[19],'P(J)*V(J)+'); writeln(F0,'+',B[20],'*I(J)*P(J)*V(J)+',B[21],'*U(J)*V(J)+'); writeln(F0,'+',B[22],'*I(J)*U(J)*V(J)+',B[23],'*P(J)*U(J)*V(J)+'); writeln(F0,'+',B[24],'*I(J)*P(J)*U(J)*V(J)+',B[25],'*Q(J)*V(J)+'); writeln(F0,'+',B[26],'*I(J)*Q(J)*V(J)+',B[27],'*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[28],'*I(J)*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[29],'*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[30],'*I(J)*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[31],'*P(J)*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[32],'*I(J)*P(J)*U(J)*Q(J)*V(J),'); end;
53
if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'ГДЕ'); writeln('I(J)=F(J)^',J1,'+',U1); writeln(F0,'I(J)=F(J)^',J1,'+',V1); writeln(F0,'Обозначение:F(J)- 1-ый фактор '); end; if (X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'P(J)=H(J)^',J2,'+',V2); writeln(F0,'Обозначение:H(J)- 2-ой фактор'); end; if (X=8)or(X=16)or(X=32) then begin writeln(F0,'U(J)=L(J)^',J3,'+',V3); writeln(F0,'Обозначение:L(J)- 3-ий фактор'); end; if (X=16)or(X=32) then begin writeln(F0,'Q(J)=K(J)^',J4,'+',V4); writeln(F0,'Обозначение:K(J)- 4-ый фактор'); end; if (X=32) then begin writeln(F0,'V(J)=M(J)^',J5,'+',V5); writeln(F0,'Обозначение:M(J)- 5-ый фактор'); end; end;{GB2820} procedure GB7000; label 1; begin repeat writeln('Вычисления показателей Z(K5)'); writeln(' по математической модели'); writeln(' с ипользованием циклов'); writeln('vvod X'); readln(X); writeln('X=',X); writeln(F0,'Вычисления показателей Z(K5)'); writeln(F0,' по математической модели'); writeln(F0,' с ипользованием циклов'); writeln(F0,'X=',X); case X of 2: I0:=73; 4: I0:=74; 8: I0:=75; 16: I0:=76; 32: I0:=77; end; if I0=73 then begin F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end;
54
writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end; GB2490; GB2540; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=74 then begin F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); end; GB2490; GB2500; GB2550; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=75 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4');
55
writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); end; GB2490; GB2500; GB2510; GB2570; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=76 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln('X-количество значений 1,2,3,4-го фактора'); writeln(F0,'F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln(F0,'X-количество значений 1,2,3,4-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); for K5:=1 to X do begin F[K5]:=F3+K5*F4;
56
writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); end; GB2490; GB2500;GB2510; GB2520; GB2600; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=77 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; M3:=0; M4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4, M(1)=M3+M4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4, M(1)=M3+M4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; M[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4,M4-шаг приращения 1,2,3,4,5-го фактора'); writeln('X-количество значений 1,2,3,4,5-го фактора'); write(F0,'F4,H4,L4,K4,M4-шаг приращения'); writeln(F0,' 1,2,3,4,5-го фактора'); writeln(F0,'X-количество значений 1,2,3,4,5-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4 M3 M4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4,M3,M4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); writeln(F0,'M3=',M3,' M4=',M4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); M[K5]:=M3+K5*M4; writeln('M(',K5,')=',M[K5]); end; GB2490; GB2500; GB2510; GB2520; GB2530; GB2670; for K5:=1 to X do
57
writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); K8:=0; K8:=Z[1]; for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; begin writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); end; for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; begin writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); end; for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94;
58
end;{GB7000} procedure tablF9; begin writeln('Значения F7 для 5% уровня знач-ти'); writeln('┌───┬───────────────────────────┐'); writeln('│ │ F9 │'); writeln('│F8 ├────┬─────┬─────┬─────┬────┤'); writeln('│ │ 1 │ 3 │ 7 │ 15 │ 31 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 2 │19.0│19.16│19.36│19.42│9.46│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 3 │9.55│ 9.28│ 8.88│ 8.71│8.62│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 4 │6.94│ 6.59│ 6.09│ 5.87│5.74│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 5 │5.79│ 5.41│ 4.88│ 4.64│4.5 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 6 │5.14│ 4.76│ 4.21│ 3.96│3.81│'); writeln('└───┴────┴─────┴─────┴─────┴────┘'); end; procedure OUT_Z_B; begin writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); writeln('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {========================Основная программа=======================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из двух'); writeln(' файлов tpgl1_1, tpl1_2(tnv1_1,tnv1_2). Математическое'); writeln(' моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программ GGL3,NV1.'); writeln(' Разработка Черного А.А.'); writeln(' Author Chernyy Anatoly Alekseevech.'); writeln(' Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,' Выполнение программы математического моделирования'); writeln(F0,' tpgl1_1(tnv1_1). Программа на языке Турбо-Паскаль,'); writeln(F0,' _X=2_,_X=4_,_X=8_,X=16,X=32.'); writeln(' _X=2_,_X=4_,_X=8_,X=16,X=32.'); writeln(F0,' Author Chernyy Anatoly Alekseevech.'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0;
59
L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; case X of 2: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); end; 4: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); end; 8: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); end; 16: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24;
60
GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); end; 32: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24; GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); vvod25; GB2480(A5,B5,J5,V5); writeln(F0,'V5=',V5); writeln('V5=',V5); end; 0: goto 2; else goto 2; end;{case} if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin F[1]:=A1; F[2]:=B1; end; if (X=4)or(X=8)or(X=16)or(X=32) then begin H[1]:=A2; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; end; if (X=8)or(X=16)or(X=32) then begin L[1]:=A3; L[2]:=A3; L[3]:=A3; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; end; if (X=16)or(X=32) then begin K[1]:=A4; K[2]:=A4; K[3]:=A4; K[4]:=A4; K[5]:=A4; K[6]:=A4; K[7]:=A4; K[8]:=A4; F[9]:=A1; H[9]:=A2; L[9]:=A3; K[9]:=B4; F[10]:=B1; H[10]:=A2; L[10]:=A3; K[10]:=B4; F[11]:=A1; H[11]:=B2; L[11]:=A3; K[11]:=B4; F[12]:=B1; H[12]:=B2; L[12]:=A3; K[12]:=B4; F[13]:=A1; H[13]:=A2; L[13]:=B3; K[13]:=B4; F[14]:=B1; H[14]:=A2; L[14]:=B3; K[14]:=B4; F[15]:=A1; H[15]:=B2; L[15]:=B3; K[15]:=B4; F[16]:=B1; H[16]:=B2; L[16]:=B3; K[16]:=B4; end; if X=32 then
61
begin M[1]:=A5; M[2]:=A5; M[3]:=A5; M[4]:=A5; M[5]:=A5; M[6]:=A5; M[7]:=A5; M[8]:=A5; M[9]:=A5; M[10]:=A5; M[11]:=A5; M[12]:=A5; M[13]:=A5; M[14]:=A5; M[15]:=A5; M[16]:=A5; F[17]:=A1; H[17]:=A2; L[17]:=A3; K[17]:=A4; M[17]:=B5; F[18]:=B1; H[18]:=A2; L[18]:=A3; K[18]:=A4; M[18]:=B5; F[19]:=A1; H[19]:=B2; L[19]:=A3; K[19]:=A4; M[19]:=B5; F[20]:=B1; H[20]:=B2; L[20]:=A3; K[20]:=A4; M[20]:=B5; F[21]:=A1; H[21]:=A2; L[21]:=B3; K[21]:=A4; M[21]:=B5; F[22]:=B1; H[22]:=A2; L[22]:=B3; K[22]:=A4; M[22]:=B5; F[23]:=A1; H[23]:=B2; L[23]:=B3; K[23]:=A4; M[23]:=B5; F[24]:=B1; H[24]:=B2; L[24]:=B3; K[24]:=A4; M[24]:=B5; F[25]:=A1; H[25]:=A2; L[25]:=A3; K[25]:=B4; M[25]:=B5; F[26]:=B1; H[26]:=A2; L[26]:=A3; K[26]:=B4; M[26]:=B5; F[27]:=A1; H[27]:=B2; L[27]:=A3; K[27]:=B4; M[27]:=B5; F[28]:=B1; H[28]:=B2; L[28]:=A3; K[28]:=B4; M[28]:=B5; F[29]:=A1; H[29]:=A2; L[29]:=B3; K[29]:=B4; M[29]:=B5; F[30]:=B1; H[30]:=A2; L[30]:=B3; K[30]:=B4; M[30]:=B5; F[31]:=A1; H[31]:=B2; L[31]:=B3; K[31]:=B4; M[31]:=B5; F[32]:=B1; H[32]:=B2; L[32]:=B3; K[32]:=B4; M[32]:=B5; end; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y[J]'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 2: GB2490; 4: begin GB2490; GB2500; end; 8: begin GB2490; GB2500; GB2510; end; 16: begin GB2490; GB2500; GB2510; GB2520; end; 32: begin GB2490; GB2500; GB2510; GB2520; GB2530; end; end;{case} GB780; case X of 4: GB810; 8: begin GB810; GB850;
62
end; 16: begin GB810; GB850; GB940; end; 32: begin GB810; GB850; GB940; GB1110; end; end;{case} writeln(' B(J) до анализа'); writeln(F0,' B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=5 then goto 5; if I0=30 then goto 3; if I0=25 then begin GB2820; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'N0-количество опытов на среднем уровне факторов'); writeln(F0,'N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов');
63
writeln(F0,'Ввод G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; writeln(F0,'S0=',S0); for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'U9-дисперсия опытов =',U9); end; if not(I0=5) then begin writeln(' Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'T-критерий T0=',T0); writeln(' B(J) после анализа'); writeln(F0,' B(J) после анализа'); for J:=1 to X do begin if T[J]
64
end; writeln('Количество статистически значимых'); writeln('коэффициентов регрессии'); writeln('K9=',K9); writeln('F9=X-1'); writeln(F0,'Количество статистически значимых'); writeln(F0,'коэффициентов регрессии'); writeln(F0,'K9=',K9); writeln(F0,'F9=X-1'); F9:=X-1; writeln('F9=',F9); writeln(F0,'F9=',F9); F9:=X-1; tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end;{case} writeln('Расчетные величины показателя'); writeln(' Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; case X of 2: OUT_F_H_L(73); 4: OUT_F_H_L(74); 8: OUT_F_H_L(75); 16: OUT_F_H_L(76); 32: OUT_F_H_L(77); end;
65
end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB2820; goto 2; end; if I0=22 then begin GB7000; goto 5; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'Результаты расчетов по модели'); if X=2 then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); GB2490; GB2540; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(73); end; if X=4 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,')'); readln(F[S],H[S]); GB2490; GB2500; GB2550; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(74); end; if X=8 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0;
66
Z[S]:=0; L[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2570; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(75); end; if X=16 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; K[S]:=0; L[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,') K(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2520; GB2600; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(76); end; if X=32 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; L[S]:=0; K[S]:=0; M[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); writeln('Ввод K(',S,') M(',S,')'); readln(K[S],M[S]); GB2490; GB2500; GB2510; GB2520; GB2530; GB2670; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(77); end; 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if (I0=11) then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin
67
GB7000; goto 2; end; writeln('Конец работы'); close(F0); end. end.{Конец программы} unit tpgl1_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6,Z2,Z3,Z4,Z5:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2,V4,V5,M3,M4:real; A4,B4,A5,B5,J4,T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0:TEXT; grMode: Integer; function ste(Q,A:real):real; procedure VVOD21; procedure VVOD22; procedure VVOD23; procedure VVOD24; procedure VVOD25; procedure GB780; procedure GB810; procedure GB850; procedure GB940; procedure GB1110; procedure GB2480(A,B,N:real; var V0:real); procedure GB2490; procedure GB2500; procedure GB2510; procedure GB2520; procedure GB2530; procedure GB2540; procedure GB2550; procedure GB2570; procedure GB2600; procedure GB2670; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then exit else begin if Q=0 then A:=1E-20; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure VVOD21; begin writeln('Ввод A1 B1 J1'); readln(A1,B1,J1); writeln(F0,'A1=',A1,' B1=',B1); writeln(F0,'J1=',J1); end; procedure VVOD22; begin writeln('Ввод A2 B2 J2'); readln(A2,B2,J2); writeln(F0,'A2=',A2,' B2=',B2);
68
writeln(F0,'J2=',J2); end; procedure VVOD23; begin writeln('Ввод A3 B3 J3'); readln(A3,B3,J3); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD24; begin writeln('Ввод A4 B4 J4'); readln(A4,B4,J4); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD25; begin writeln('Ввод A5 B5 J5'); readln(A5,B5,J5); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure GB780; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; end; procedure GB810; begin SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[3]:=O[3]+P[J]*P[J]; end; B[3]:=SS/O[3]; SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[4]:=O[4]+(I[J]*P[J])*(I[J]*P[J]); end; B[4]:=SS/O[4]; end;{GB810}
69
procedure GB850; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[5]:=O[5]+U[J]*U[J]; end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[6]:=O[6]+(I[J]*U[J])*(I[J]*U[J]); end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[7]:=O[7]+(P[J]*U[J])*(P[J]*U[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[8]:=O[8]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[8]:=SS/O[8]; end;{GB850} procedure GB940; begin SS:=0; O[9]:=0; for j:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[9]:=O[9]+Q[J]*Q[J]; end; B[9]:=SS/O[9]; SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[10]:=O[10]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*Y[J]; O[11]:=O[11]+(P[J]*Q[J])*(P[J]*Q[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin
70
SS:=SS+I[J]*P[J]*Q[J]*Y[J]; O[12]:=O[12]+(I[J]*P[J]*Q[J])*(I[J]*P[J]*Q[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[13]:=O[13]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[14]:=O[14]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*Y[J]; O[15]:=O[15]+(P[J]*U[J]*Q[J])*(P[J]*U[J]*Q[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*Y[J]; O[16]:=O[16]+(I[J]*P[J]*U[J]*Q[J])*(I[J]*P[J]*U[J]*Q[J]); end; B[16]:=SS/O[16]; end;{GB940} procedure GB1110; begin SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[17]:=O[17]+V[J]*V[J]; end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[18]:=O[18]+(I[J]*V[J])*(I[J]*V[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[19]:=O[19]+(P[J]*V[J])*(P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0;
71
for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[20]:=O[20]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+U[J]*V[J]*Y[J]; O[21]:=O[21]+(U[J]*V[J])*(U[J]*V[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*V[J]*Y[J]; O[22]:=O[22]+(I[J]*U[J]*V[J])*(I[J]*U[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*V[J]*Y[J]; O[23]:=O[23]+(P[J]*U[J]*V[J])*(P[J]*U[J]*V[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*P[J]*U[J]*V[J])*(I[J]*P[J]*U[J]*V[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[25]:=O[25]+(Q[J]*V[J])*(Q[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[26]:=O[26]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*V[J]*Y[J]; O[27]:=O[27]+(P[J]*Q[J]*V[J])*(P[J]*Q[J]*V[J]); end; B[27]:=SS/O[27]; SS:=0; O[28]:=0; for J:=1 to X do
72
begin SS:=SS+I[J]*P[J]*Q[J]*V[J]*Y[J]; O[28]:=O[28]+(I[J]*P[J]*Q[J]*V[J])*(I[J]*P[J]*Q[J]*V[J]); end; B[28]:=SS/O[28]; SS:=0; O[29]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*V[J]*Y[J]; O[29]:=O[29]+(U[J]*Q[J]*V[J])*(U[J]*Q[J]*V[J]); end; B[29]:=SS/O[29]; SS:=0; O[30]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*V[J]*Y[J]; O[30]:=O[30]+(I[J]*U[J]*Q[J]*V[J])*(I[J]*U[J]*Q[J]*V[J]); end; B[30]:=SS/O[30]; SS:=0; O[31]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*V[J]*Y[J]; O[31]:=O[31]+(P[J]*U[J]*Q[J]*V[J])*(P[J]*U[J]*Q[J]*V[J]); end; B[31]:=SS/O[31]; SS:=0; O[32]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*V[J]*Y[J]; O[32]:=O[32]+(I[J]*P[J]*U[J]*Q[J]*V[J])* (I[J]*P[J]*U[J]*Q[J]*V[J]); end; B[32]:=SS/O[32]; end;{GB1110} procedure GB2480(A,B,N:real; var V0:real); begin V0:=-(ste(A,N)+ste(B,N))/2; write('Коэффициент ортогонализации '); write(F0,'Коэффициент ортогонализации '); end;{GB2480} procedure GB2490; begin for J:=1 to X do I[J]:=ste(F[J],J1)+V1; end;{GB2490} procedure GB2500; begin for J:=1 to X do P[J]:=ste(H[J],J2)+V2; end;{GB2500} procedure GB2510; begin for J:=1 to X do U[J]:=ste(L[J],J3)+V3; end;{GB2510} procedure GB2520;
73
begin for J:=1 to X do Q[J]:=ste(K[J],J4)+V4; end;{GB2520} procedure GB2530; begin for J:=1 to X do V[J]:=ste(M[J],J5)+V5; end;{GB2530} procedure GB2540; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]; end;{GB2540} procedure GB2550; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; end;{GB2550} procedure GB2570; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; Z[J]:=N3+N4+B[8]*I[J]*P[J]*U[J]; end; end;{GB2570} procedure GB2600; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; Z[J]:=N3+N4+N5+N6+N7+B[16]*I[J]*P[J]*U[J]*Q[J]; end; end;{GB2600} procedure GB2670; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; R0:=B[16]*I[J]*P[J]*U[J]*Q[J]+B[17]*V[J]; R4:=B[18]*I[J]*V[J]+B[19]*P[J]*V[J]+B[20]*I[J]*P[J]*V[J]; R5:=B[21]*U[J]*V[J]+B[22]*I[J]*U[J]*V[J]; R6:=B[23]*P[J]*U[J]*V[J]+B[24]*I[J]*P[J]*U[J]*V[J]; Z2:=B[25]*Q[J]*V[J]+B[26]*I[J]*Q[J]*V[J]; Z3:=B[27]*P[J]*Q[J]*V[J]+B[28]*I[J]*P[J]*Q[J]*V[J]; Z4:=B[29]*U[J]*Q[J]*V[J]+B[30]*I[J]*U[J]*Q[J]*V[J]; Z5:=B[31]*P[J]*U[J]*Q[J]*V[J]+B[32]*I[J]*P[J]*U[J]*Q[J]*V[J];
74
Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6+Z2+Z3+Z4+Z5; end; end;{GB2670} begin end.
75
Программа TNV3(два модуля tpgl3, 1-я часть, Х=2, Х=4, Х=8, _Х=16_, Х=32, «система» после «адекватно», 1.1-11.2)…tpgl3 program tpgl1_1; uses tpgl1_2; label 1,2,3,4,5; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значе'); writeln(F0,'ние │'); write(F0,'│ J ├──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │'); writeln(F0,' L(J) │ Z(J) │'); end; if PR=76 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значение '); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ Z(J) │'); end; if PR=77 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'────────────────────────────────┐'); write(F0,'│ │ Зна'); writeln(F0,'чение │'); write(F0,'│ J ├──────────┬──────────┬─────────'); writeln(F0,'─┬──────────┬──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ M(J) │ Z(J) │'); end;
76
if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; if PR=76 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',K[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end; if PR=77 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼────────'); writeln(F0,'──┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); write(F0,L[J]:10,'│',K[J]:10,'│',M[J]:10,'│'); writeln(F0,Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end;
77
end;{OUT_F_H_L} procedure GB2820; begin writeln(F0,'Математическая модель'); if X=2 then begin writeln(F0,'X=2. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J),'); end; if X=4 then begin writeln(F0,'X=4. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J),'); end; if X=8 then begin writeln(F0,'X=8. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J),'); end; if X=16 then begin writeln(F0,'X=16. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J),'); end; if X=32 then begin writeln(F0,'X=32. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J)+',B[17],'*V(J)+'); writeln(F0,'+',B[18],'*I(J)*V(J)+',B[19],'P(J)*V(J)+'); writeln(F0,'+',B[20],'*I(J)*P(J)*V(J)+',B[21],'*U(J)*V(J)+'); writeln(F0,'+',B[22],'*I(J)*U(J)*V(J)+',B[23],'*P(J)*U(J)*V(J)+'); writeln(F0,'+',B[24],'*I(J)*P(J)*U(J)*V(J)+',B[25],'*Q(J)*V(J)+'); writeln(F0,'+',B[26],'*I(J)*Q(J)*V(J)+',B[27],'*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[28],'*I(J)*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[29],'*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[30],'*I(J)*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[31],'*P(J)*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[32],'*I(J)*P(J)*U(J)*Q(J)*V(J),'); end;
78
if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1,'+',V1); writeln(F0,'Обозначение:F(J)- 1-ый фактор '); end; if (X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'P(J)=H(J)^',J2,'+',V2); writeln(F0,'Обозначение:H(J)- 2-ой фактор'); end; if (X=8)or(X=16)or(X=32) then begin writeln(F0,'U(J)=L(J)^',J3,'+',V3); writeln(F0,'Обозначение:L(J)- 3-ий фактор'); end; if (X=16)or(X=32) then begin writeln(F0,'Q(J)=K(J)^',J4,'+',V4); writeln(F0,'Обозначение:K(J)- 4-ый фактор'); end; if (X=32) then begin writeln(F0,'V(J)=M(J)^',J5,'+',V5); writeln(F0,'Обозначение:M(J)- 5-ый фактор'); end; end;{GB2820} procedure GB7000; label 1; begin repeat writeln('Вычисления показателей Z(K5)'); writeln(' по математической модели'); writeln(' с ипользованием циклов'); writeln('vvod X'); readln(X); writeln('X=',X); writeln(F0,'Вычисления показателей Z(K5)'); writeln(F0,' по математической модели'); writeln(F0,' с ипользованием циклов'); writeln(F0,'X=',X); case X of 2: I0:=73; 4: I0:=74; 8: I0:=75; 16: I0:=76; 32: I0:=77; end; if I0=73 then begin F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора');
79
writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end; GB2490; GB2540; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=74 then begin F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); end; GB2490; GB2500; GB2550; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=75 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4');
80
for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); end; GB2490; GB2500; GB2510; GB2570; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=76 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln('X-количество значений 1,2,3,4-го фактора'); writeln(F0,'F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln(F0,'X-количество значений 1,2,3,4-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]);
81
H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); end; GB2490; GB2500;GB2510; GB2520; GB2600; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=77 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; M3:=0; M4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4, M(1)=M3+M4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4, M(1)=M3+M4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; M[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4,M4-шаг приращения 1,2,3,4,5-го фактора'); writeln('X-количество значений 1,2,3,4,5-го фактора'); write(F0,'F4,H4,L4,K4,M4-шаг приращения'); writeln(F0,' 1,2,3,4,5-го фактора'); writeln(F0,'X-количество значений 1,2,3,4,5-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4 M3 M4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4,M3,M4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); writeln(F0,'M3=',M3,' M4=',M4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); M[K5]:=M3+K5*M4; writeln('M(',K5,')=',M[K5]); end; GB2490; GB2500; GB2510; GB2520; GB2530; GB2670; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]);
82
OUT_F_H_L(I0); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); K8:=0; K8:=Z[1]; for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; begin writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); end; for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; begin writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); end; for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000}
83
procedure tablF9; begin writeln('Значения F7 для 5% уровня знач-ти'); writeln('┌───┬───────────────────────────┐'); writeln('│ │ F9 │'); writeln('│F8 ├────┬─────┬─────┬─────┬────┤'); writeln('│ │ 1 │ 3 │ 7 │ 15 │ 31 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 2 │19.0│19.16│19.36│19.42│9.46│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 3 │9.55│ 9.28│ 8.88│ 8.71│8.62│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 4 │6.94│ 6.59│ 6.09│ 5.87│5.74│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 5 │5.79│ 5.41│ 4.88│ 4.64│4.5 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 6 │5.14│ 4.76│ 4.21│ 3.96│3.81│'); writeln('└───┴────┴─────┴─────┴─────┴────┘'); end; procedure OUT_Z_B; begin writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); writeln('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {========================Основная программа=======================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из двух'); writeln(' файлов tpgl1_1, tpl1_2(tnv3_1,tnv3_2). Математическое'); writeln(' моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программ GGL3,NV1.'); writeln(' Разработка Черного А.А.'); writeln(' Author Chernyy Anatoly Alekseevech.'); writeln(' Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,' Выполнение программы математического моделирования'); writeln(F0,' tpgl1_1(tnv3_1).Программа на языке Турбо-Паскаль,'); writeln(F0,' X=2, X=4, X=8, _X=16_, X=32.'); writeln(' X=2, X=4, X=8, _X=16_, X=32.'); writeln(F0,' Author Chernyy Anatoly Alekseevech.'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0;
84
K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; case X of 2: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); end; 4: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); end; 8: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); end; 16: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24; GB2480(A4,B4,J4,V4);
85
writeln(F0,'V4=',V4); writeln('V4=',V4); end; 32: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24; GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); vvod25; GB2480(A5,B5,J5,V5); writeln(F0,'V5=',V5); writeln('V5=',V5); end; 0: goto 2; else goto 2; end;{case} if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin F[1]:=A1; F[2]:=B1; end; if (X=4)or(X=8)or(X=16)or(X=32) then begin H[1]:=A2; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; end; if (X=8)or(X=16)or(X=32) then begin L[1]:=A3; L[2]:=A3; L[3]:=A3; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; end; if (X=16)or(X=32) then begin K[1]:=A4; K[2]:=A4; K[3]:=A4; K[4]:=A4; K[5]:=A4; K[6]:=A4; K[7]:=A4; K[8]:=A4; F[9]:=A1; H[9]:=A2; L[9]:=A3; K[9]:=B4; F[10]:=B1; H[10]:=A2; L[10]:=A3; K[10]:=B4; F[11]:=A1; H[11]:=B2; L[11]:=A3; K[11]:=B4; F[12]:=B1; H[12]:=B2; L[12]:=A3; K[12]:=B4; F[13]:=A1; H[13]:=A2; L[13]:=B3; K[13]:=B4; F[14]:=B1; H[14]:=A2; L[14]:=B3; K[14]:=B4; F[15]:=A1; H[15]:=B2; L[15]:=B3; K[15]:=B4; F[16]:=B1; H[16]:=B2; L[16]:=B3; K[16]:=B4; end; if X=32 then begin
86
M[1]:=A5; M[2]:=A5; M[3]:=A5; M[4]:=A5; M[5]:=A5; M[6]:=A5; M[7]:=A5; M[8]:=A5; M[9]:=A5; M[10]:=A5; M[11]:=A5; M[12]:=A5; M[13]:=A5; M[14]:=A5; M[15]:=A5; M[16]:=A5; F[17]:=A1; H[17]:=A2; L[17]:=A3; K[17]:=A4; M[17]:=B5; F[18]:=B1; H[18]:=A2; L[18]:=A3; K[18]:=A4; M[18]:=B5; F[19]:=A1; H[19]:=B2; L[19]:=A3; K[19]:=A4; M[19]:=B5; F[20]:=B1; H[20]:=B2; L[20]:=A3; K[20]:=A4; M[20]:=B5; F[21]:=A1; H[21]:=A2; L[21]:=B3; K[21]:=A4; M[21]:=B5; F[22]:=B1; H[22]:=A2; L[22]:=B3; K[22]:=A4; M[22]:=B5; F[23]:=A1; H[23]:=B2; L[23]:=B3; K[23]:=A4; M[23]:=B5; F[24]:=B1; H[24]:=B2; L[24]:=B3; K[24]:=A4; M[24]:=B5; F[25]:=A1; H[25]:=A2; L[25]:=A3; K[25]:=B4; M[25]:=B5; F[26]:=B1; H[26]:=A2; L[26]:=A3; K[26]:=B4; M[26]:=B5; F[27]:=A1; H[27]:=B2; L[27]:=A3; K[27]:=B4; M[27]:=B5; F[28]:=B1; H[28]:=B2; L[28]:=A3; K[28]:=B4; M[28]:=B5; F[29]:=A1; H[29]:=A2; L[29]:=B3; K[29]:=B4; M[29]:=B5; F[30]:=B1; H[30]:=A2; L[30]:=B3; K[30]:=B4; M[30]:=B5; F[31]:=A1; H[31]:=B2; L[31]:=B3; K[31]:=B4; M[31]:=B5; F[32]:=B1; H[32]:=B2; L[32]:=B3; K[32]:=B4; M[32]:=B5; end; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y[J]'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 2: GB2490; 4: begin GB2490; GB2500; end; 8: begin GB2490; GB2500; GB2510; end; 16: begin GB2490; GB2500; GB2510; GB2520; end; 32: begin GB2490; GB2500; GB2510; GB2520; GB2530; end; end;{case} GB780; case X of 4: GB810; 8: begin GB810; GB850; end;
87
16: begin GB810; GB850; GB940; end; 32: begin GB810; GB850; GB940; GB1110; end; end;{case} writeln(' B(J) до анализа'); writeln(F0,' B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=5 then goto 5; if I0=30 then goto 3; if I0=25 then begin GB2820; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'N0-количество опытов на среднем уровне факторов'); writeln(F0,'N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'Ввод G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do
88
begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; writeln(F0,'S0=',S0); for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'U9-дисперсия опытов =',U9); end; if not(I0=5) then begin writeln(' Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'T-критерий T0=',T0); writeln(' B(J) после анализа'); writeln(F0,' B(J) после анализа'); for J:=1 to X do begin if T[J]
89
writeln('K9=',K9); writeln('F9=X-1'); writeln(F0,'Количество статистически значимых'); writeln(F0,'коэффициентов регрессии'); writeln(F0,'K9=',K9); writeln(F0,'F9=X-1'); F9:=X-1; writeln('F9=',F9); writeln(F0,'F9=',F9); F9:=X-1; tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end;{case} writeln('Расчетные величины показателя'); writeln(' Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; if X=16 then begin writeln(F0,'X=16. System, 1.1 - 11.2, finish 32.2.'); writeln(F0,'1.1.','A2=',A2,'A3=',A3,'A4=',A4,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'A3=',A3,'A4=',A4,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','A2=',A2,'B3=',B3,'A4=',A4,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'2.2.','A2=',A2,'B3=',B3,'A4=',A4,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'3.1.','A2=',A2,'A3=',A3,'B4=',B4,'A1=',A1,'Z(9)=',Z[9]); writeln(F0,'3.2.','A2=',A2,'A3=',A3,'B4=',B4,'B1=',B1,'Z(10)=',Z[10]); writeln(F0,'4.1.','A2=',A2,'B3=',B3,'B4=',B4,'A1=',A1,'Z(13)=',Z[13]);
90
writeln(F0,'4.2.','A2=',A2,'B3=',B3,'B4=',B4,'B1=',B1,'Z(14)=',Z[14]); writeln(F0,'5.1.','B2=',B2,'A3=',A3,'A4=',A4,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'5.2.','B2=',B2,'A3=',A3,'A4=',A4,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'6.1.','B2=',B2,'B3=',B3,'A4=',A4,'A1=',A1,'Z(7)=',Z[7]); writeln(F0,'6.2.','B2=',B2,'B3=',B3,'A4=',A4,'B1=',B1,'Z(8)=',Z[8]); writeln(F0,'7.1.','B2=',B2,'A3=',A3,'B4=',B4,'A1=',A1,'Z(11)=',Z[11]); writeln(F0,'7.2.','B2=',B2,'A3=',A3,'B4=',B4,'B1=',B1,'Z(12)=',Z[12]); writeln(F0,'8.1.','B2=',B2,'B3=',B3,'B4=',B4,'A1=',A1,'Z(15)=',Z[15]); writeln(F0,'8.2.','B2=',B2,'B3=',B3,'B4=',B4,'B1=',B1,'Z(16)=',Z[16]); writeln(F0,'9.1.','A1=',A1,'A3=',A3,'A4=',A4,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'9.2.','A1=',A1,'A3=',A3,'A4=',A4,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'10.1.','A1=',A1,'B3=',B3,'A4=',A4,'A2=',A2,'Z(5)=',Z[5]); writeln(F0,'10.2.','A1=',A1,'B3=',B3,'A4=',A4,'B2=',B2,'Z(7)=',Z[7]); writeln(F0,'11.1.','A1=',A1,'A3=',A3,'B4=',B4,'A2=',A2,'Z(9)=',Z[9]); writeln(F0,'11.2.','A1=',A1,'A3=',A3,'B4=',B4,'B2=',B2,'Z(11)=',Z[11]); end; case X of 2: OUT_F_H_L(73); 4: OUT_F_H_L(74); 8: OUT_F_H_L(75); 16: OUT_F_H_L(76); 32: OUT_F_H_L(77); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB2820; goto 2; end; if I0=22 then begin GB7000; goto 5; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'Результаты расчетов по модели'); if X=2 then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')');
91
readln(F[S]); GB2490; GB2540; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(73); end; if X=4 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,')'); readln(F[S],H[S]); GB2490; GB2500; GB2550; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(74); end; if X=8 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; L[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2570; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(75); end; if X=16 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; K[S]:=0; L[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,') K(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2520; GB2600; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(76); end; if X=32 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; L[S]:=0; K[S]:=0; M[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); writeln('Ввод K(',S,') M(',S,')'); readln(K[S],M[S]); GB2490; GB2500; GB2510; GB2520; GB2530; GB2670;
92
writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(77); end; 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if (I0=11) then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end. end.{Конец программы} unit tpgl1_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6,Z2,Z3,Z4,Z5:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2,V4,V5,M3,M4:real; A4,B4,A5,B5,J4,T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0:TEXT; grMode: Integer; function ste(Q,A:real):real; procedure VVOD21; procedure VVOD22; procedure VVOD23; procedure VVOD24; procedure VVOD25; procedure GB780; procedure GB810; procedure GB850; procedure GB940; procedure GB1110; procedure GB2480(A,B,N:real; var V0:real); procedure GB2490; procedure GB2500; procedure GB2510; procedure GB2520; procedure GB2530; procedure GB2540; procedure GB2550; procedure GB2570; procedure GB2600; procedure GB2670; Implementation function ste(Q,A:real):real;
93
{Функция возведения в степень} begin if A<0 then exit else begin if Q=0 then A:=1E-20; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure VVOD21; begin writeln('Ввод A1 B1 J1'); readln(A1,B1,J1); writeln(F0,'A1=',A1,' B1=',B1); writeln(F0,'J1=',J1); end; procedure VVOD22; begin writeln('Ввод A2 B2 J2'); readln(A2,B2,J2); writeln(F0,'A2=',A2,' B2=',B2); writeln(F0,'J2=',J2); end; procedure VVOD23; begin writeln('Ввод A3 B3 J3'); readln(A3,B3,J3); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD24; begin writeln('Ввод A4 B4 J4'); readln(A4,B4,J4); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD25; begin writeln('Ввод A5 B5 J5'); readln(A5,B5,J5); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure GB780; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do
94
begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; end; procedure GB810; begin SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[3]:=O[3]+P[J]*P[J]; end; B[3]:=SS/O[3]; SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[4]:=O[4]+(I[J]*P[J])*(I[J]*P[J]); end; B[4]:=SS/O[4]; end;{GB810} procedure GB850; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[5]:=O[5]+U[J]*U[J]; end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[6]:=O[6]+(I[J]*U[J])*(I[J]*U[J]); end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[7]:=O[7]+(P[J]*U[J])*(P[J]*U[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[8]:=O[8]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[8]:=SS/O[8]; end;{GB850} procedure GB940; begin SS:=0; O[9]:=0;
95
for j:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[9]:=O[9]+Q[J]*Q[J]; end; B[9]:=SS/O[9]; SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[10]:=O[10]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*Y[J]; O[11]:=O[11]+(P[J]*Q[J])*(P[J]*Q[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Q[J]*Y[J]; O[12]:=O[12]+(I[J]*P[J]*Q[J])*(I[J]*P[J]*Q[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[13]:=O[13]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[14]:=O[14]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*Y[J]; O[15]:=O[15]+(P[J]*U[J]*Q[J])*(P[J]*U[J]*Q[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*Y[J]; O[16]:=O[16]+(I[J]*P[J]*U[J]*Q[J])*(I[J]*P[J]*U[J]*Q[J]); end; B[16]:=SS/O[16]; end;{GB940} procedure GB1110;
96
begin SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[17]:=O[17]+V[J]*V[J]; end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[18]:=O[18]+(I[J]*V[J])*(I[J]*V[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[19]:=O[19]+(P[J]*V[J])*(P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[20]:=O[20]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+U[J]*V[J]*Y[J]; O[21]:=O[21]+(U[J]*V[J])*(U[J]*V[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*V[J]*Y[J]; O[22]:=O[22]+(I[J]*U[J]*V[J])*(I[J]*U[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*V[J]*Y[J]; O[23]:=O[23]+(P[J]*U[J]*V[J])*(P[J]*U[J]*V[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*P[J]*U[J]*V[J])*(I[J]*P[J]*U[J]*V[J]); end; B[24]:=SS/O[24];
97
SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[25]:=O[25]+(Q[J]*V[J])*(Q[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[26]:=O[26]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*V[J]*Y[J]; O[27]:=O[27]+(P[J]*Q[J]*V[J])*(P[J]*Q[J]*V[J]); end; B[27]:=SS/O[27]; SS:=0; O[28]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Q[J]*V[J]*Y[J]; O[28]:=O[28]+(I[J]*P[J]*Q[J]*V[J])*(I[J]*P[J]*Q[J]*V[J]); end; B[28]:=SS/O[28]; SS:=0; O[29]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*V[J]*Y[J]; O[29]:=O[29]+(U[J]*Q[J]*V[J])*(U[J]*Q[J]*V[J]); end; B[29]:=SS/O[29]; SS:=0; O[30]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*V[J]*Y[J]; O[30]:=O[30]+(I[J]*U[J]*Q[J]*V[J])*(I[J]*U[J]*Q[J]*V[J]); end; B[30]:=SS/O[30]; SS:=0; O[31]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*V[J]*Y[J]; O[31]:=O[31]+(P[J]*U[J]*Q[J]*V[J])*(P[J]*U[J]*Q[J]*V[J]); end; B[31]:=SS/O[31]; SS:=0; O[32]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*V[J]*Y[J]; O[32]:=O[32]+(I[J]*P[J]*U[J]*Q[J]*V[J])* (I[J]*P[J]*U[J]*Q[J]*V[J]); end; B[32]:=SS/O[32];
98
end;{GB1110} procedure GB2480(A,B,N:real; var V0:real); begin V0:=-(ste(A,N)+ste(B,N))/2; write('Коэффициент ортогонализации '); write(F0,'Коэффициент ортогонализации '); end;{GB2480} procedure GB2490; begin for J:=1 to X do I[J]:=ste(F[J],J1)+V1; end;{GB2490} procedure GB2500; begin for J:=1 to X do P[J]:=ste(H[J],J2)+V2; end;{GB2500} procedure GB2510; begin for J:=1 to X do U[J]:=ste(L[J],J3)+V3; end;{GB2510} procedure GB2520; begin for J:=1 to X do Q[J]:=ste(K[J],J4)+V4; end;{GB2520} procedure GB2530; begin for J:=1 to X do V[J]:=ste(M[J],J5)+V5; end;{GB2530} procedure GB2540; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]; end;{GB2540} procedure GB2550; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; end;{GB2550} procedure GB2570; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; Z[J]:=N3+N4+B[8]*I[J]*P[J]*U[J]; end; end;{GB2570} procedure GB2600; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J];
99
N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; Z[J]:=N3+N4+N5+N6+N7+B[16]*I[J]*P[J]*U[J]*Q[J]; end; end;{GB2600} procedure GB2670; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; R0:=B[16]*I[J]*P[J]*U[J]*Q[J]+B[17]*V[J]; R4:=B[18]*I[J]*V[J]+B[19]*P[J]*V[J]+B[20]*I[J]*P[J]*V[J]; R5:=B[21]*U[J]*V[J]+B[22]*I[J]*U[J]*V[J]; R6:=B[23]*P[J]*U[J]*V[J]+B[24]*I[J]*P[J]*U[J]*V[J]; Z2:=B[25]*Q[J]*V[J]+B[26]*I[J]*Q[J]*V[J]; Z3:=B[27]*P[J]*Q[J]*V[J]+B[28]*I[J]*P[J]*Q[J]*V[J]; Z4:=B[29]*U[J]*Q[J]*V[J]+B[30]*I[J]*U[J]*Q[J]*V[J]; Z5:=B[31]*P[J]*U[J]*Q[J]*V[J]+B[32]*I[J]*P[J]*U[J]*Q[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6+Z2+Z3+Z4+Z5; end; end;{GB2670} begin end.
100
Программа TNV4(два модуля tpgl3, 2-я часть, Х=2, Х=4, Х=8, _Х=16_, Х=32, «система» после «адекватно», 12.1-22.2)… program tpgl1_1; uses tpgl1_2; label 1,2,3,4,5; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значе'); writeln(F0,'ние │'); write(F0,'│ J ├──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │'); writeln(F0,' L(J) │ Z(J) │'); end; if PR=76 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значение '); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ Z(J) │'); end; if PR=77 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'────────────────────────────────┐'); write(F0,'│ │ Зна'); writeln(F0,'чение │'); write(F0,'│ J ├──────────┬──────────┬─────────'); writeln(F0,'─┬──────────┬──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ M(J) │ Z(J) │'); end;
101
if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; if PR=76 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',K[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end; if PR=77 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼────────'); writeln(F0,'──┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); write(F0,L[J]:10,'│',K[J]:10,'│',M[J]:10,'│'); writeln(F0,Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end;
102
end;{OUT_F_H_L} procedure GB2820; begin writeln(F0,'Математическая модель'); if X=2 then begin writeln(F0,'X=2. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J),'); end; if X=4 then begin writeln(F0,'X=4. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J),'); end; if X=8 then begin writeln(F0,'X=8. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J),'); end; if X=16 then begin writeln('X=16. Model'); writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'X=16.Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J),'); end; if X=32 then begin writeln(F0,'X=32. Model'); writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J)+',B[17],'*V(J)+'); writeln(F0,'+',B[18],'*I(J)*V(J)+',B[19],'P(J)*V(J)+'); writeln(F0,'+',B[20],'*I(J)*P(J)*V(J)+',B[21],'*U(J)*V(J)+'); writeln(F0,'+',B[22],'*I(J)*U(J)*V(J)+',B[23],'*P(J)*U(J)*V(J)+'); writeln(F0,'+',B[24],'*I(J)*P(J)*U(J)*V(J)+',B[25],'*Q(J)*V(J)+'); writeln(F0,'+',B[26],'*I(J)*Q(J)*V(J)+',B[27],'*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[28],'*I(J)*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[29],'*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[30],'*I(J)*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[31],'*P(J)*U(J)*Q(J)*V(J)+');
103
writeln(F0,'+',B[32],'*I(J)*P(J)*U(J)*Q(J)*V(J),'); end; if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1,'+',V1); writeln(F0,'Обозначение:F(J)- 1-ый фактор '); end; if (X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'P(J)=H(J)^',J2,'+',V2); writeln(F0,'Обозначение:H(J)- 2-ой фактор'); end; if (X=8)or(X=16)or(X=32) then begin writeln(F0,'U(J)=L(J)^',J3,'+',V3); writeln(F0,'Обозначение:L(J)- 3-ий фактор'); end; if (X=16)or(X=32) then begin writeln(F0,'Q(J)=K(J)^',J4,'+',V4); writeln(F0,'Обозначение:K(J)- 4-ый фактор'); end; if (X=32) then begin writeln(F0,'V(J)=M(J)^',J5,'+',V5); writeln(F0,'Обозначение:M(J)- 5-ый фактор'); end; end;{GB2820} procedure GB7000; label 1; begin repeat writeln('Вычисления показателей Z(K5)'); writeln(' по математической модели'); writeln(' с ипользованием циклов'); writeln('vvod X'); readln(X); writeln('X=',X); writeln(F0,'Вычисления показателей Z(K5)'); writeln(F0,' по математической модели'); writeln(F0,' с ипользованием циклов'); writeln(F0,'X=',X); case X of 2: I0:=73; 4: I0:=74; 8: I0:=75; 16: I0:=76; 32: I0:=77; end; if I0=73 then begin F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0;
104
end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end; GB2490; GB2540; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=74 then begin F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); end; GB2490; GB2500; GB2550; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=75 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0;
105
writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); end; GB2490; GB2500; GB2510; GB2570; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=76 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln('X-количество значений 1,2,3,4-го фактора'); writeln(F0,'F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln(F0,'X-количество значений 1,2,3,4-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); for K5:=1 to X do begin
106
F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); end; GB2490; GB2500;GB2510; GB2520; GB2600; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=77 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; M3:=0; M4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4, M(1)=M3+M4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4, M(1)=M3+M4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; M[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4,M4-шаг приращения 1,2,3,4,5-го фактора'); writeln('X-количество значений 1,2,3,4,5-го фактора'); write(F0,'F4,H4,L4,K4,M4-шаг приращения'); writeln(F0,' 1,2,3,4,5-го фактора'); writeln(F0,'X-количество значений 1,2,3,4,5-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4 M3 M4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4,M3,M4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); writeln(F0,'M3=',M3,' M4=',M4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); M[K5]:=M3+K5*M4; writeln('M(',K5,')=',M[K5]); end; GB2490; GB2500; GB2510; GB2520; GB2530; GB2670;
107
for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); K8:=0; K8:=Z[1]; for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; begin writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); end; for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; begin writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); end; for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1;
108
1: until I0=94; end;{GB7000} procedure tablF9; begin writeln('Значения F7 для 5% уровня знач-ти'); writeln('┌───┬───────────────────────────┐'); writeln('│ │ F9 │'); writeln('│F8 ├────┬─────┬─────┬─────┬────┤'); writeln('│ │ 1 │ 3 │ 7 │ 15 │ 31 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 2 │19.0│19.16│19.36│19.42│9.46│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 3 │9.55│ 9.28│ 8.88│ 8.71│8.62│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 4 │6.94│ 6.59│ 6.09│ 5.87│5.74│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 5 │5.79│ 5.41│ 4.88│ 4.64│4.5 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 6 │5.14│ 4.76│ 4.21│ 3.96│3.81│'); writeln('└───┴────┴─────┴─────┴─────┴────┘'); end; procedure OUT_Z_B; begin writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); writeln('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {========================Основная программа=======================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из двух'); writeln(' файлов tpgl1_1, tpl1_2(tnv4_1,tnv4_2). Математическое'); writeln(' моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программ GGL3,NV1.'); writeln(' Разработка Черного А.А.'); writeln(' Author Chernyy Anatoly Alekseevech.'); writeln(' Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,' Выполнение программы математического моделирования'); writeln(F0,' tpgl1_1(tnv4_1). Программа на языке Турбо-Паскаль,'); writeln(F0,' X=2, X=4, X=8, _X=16_, X=32.'); writeln(' X=2, X=4, X=8, _X=16_, X=32.'); writeln(F0,' Author Chernyy Anatoly Alekseevech.');
109
J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; case X of 2: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); end; 4: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); end; 8: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); end; 16: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3);
110
vvod24; GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); end; 32: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24; GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); vvod25; GB2480(A5,B5,J5,V5); writeln(F0,'V5=',V5); writeln('V5=',V5); end; 0: goto 2; else goto 2; end;{case} if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin F[1]:=A1; F[2]:=B1; end; if (X=4)or(X=8)or(X=16)or(X=32) then begin H[1]:=A2; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; end; if (X=8)or(X=16)or(X=32) then begin L[1]:=A3; L[2]:=A3; L[3]:=A3; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; end; if (X=16)or(X=32) then begin K[1]:=A4; K[2]:=A4; K[3]:=A4; K[4]:=A4; K[5]:=A4; K[6]:=A4; K[7]:=A4; K[8]:=A4; F[9]:=A1; H[9]:=A2; L[9]:=A3; K[9]:=B4; F[10]:=B1; H[10]:=A2; L[10]:=A3; K[10]:=B4; F[11]:=A1; H[11]:=B2; L[11]:=A3; K[11]:=B4; F[12]:=B1; H[12]:=B2; L[12]:=A3; K[12]:=B4; F[13]:=A1; H[13]:=A2; L[13]:=B3; K[13]:=B4; F[14]:=B1; H[14]:=A2; L[14]:=B3; K[14]:=B4; F[15]:=A1; H[15]:=B2; L[15]:=B3; K[15]:=B4; F[16]:=B1; H[16]:=B2; L[16]:=B3; K[16]:=B4; end;
111
if X=32 then begin M[1]:=A5; M[2]:=A5; M[3]:=A5; M[4]:=A5; M[5]:=A5; M[6]:=A5; M[7]:=A5; M[8]:=A5; M[9]:=A5; M[10]:=A5; M[11]:=A5; M[12]:=A5; M[13]:=A5; M[14]:=A5; M[15]:=A5; M[16]:=A5; F[17]:=A1; H[17]:=A2; L[17]:=A3; K[17]:=A4; M[17]:=B5; F[18]:=B1; H[18]:=A2; L[18]:=A3; K[18]:=A4; M[18]:=B5; F[19]:=A1; H[19]:=B2; L[19]:=A3; K[19]:=A4; M[19]:=B5; F[20]:=B1; H[20]:=B2; L[20]:=A3; K[20]:=A4; M[20]:=B5; F[21]:=A1; H[21]:=A2; L[21]:=B3; K[21]:=A4; M[21]:=B5; F[22]:=B1; H[22]:=A2; L[22]:=B3; K[22]:=A4; M[22]:=B5; F[23]:=A1; H[23]:=B2; L[23]:=B3; K[23]:=A4; M[23]:=B5; F[24]:=B1; H[24]:=B2; L[24]:=B3; K[24]:=A4; M[24]:=B5; F[25]:=A1; H[25]:=A2; L[25]:=A3; K[25]:=B4; M[25]:=B5; F[26]:=B1; H[26]:=A2; L[26]:=A3; K[26]:=B4; M[26]:=B5; F[27]:=A1; H[27]:=B2; L[27]:=A3; K[27]:=B4; M[27]:=B5; F[28]:=B1; H[28]:=B2; L[28]:=A3; K[28]:=B4; M[28]:=B5; F[29]:=A1; H[29]:=A2; L[29]:=B3; K[29]:=B4; M[29]:=B5; F[30]:=B1; H[30]:=A2; L[30]:=B3; K[30]:=B4; M[30]:=B5; F[31]:=A1; H[31]:=B2; L[31]:=B3; K[31]:=B4; M[31]:=B5; F[32]:=B1; H[32]:=B2; L[32]:=B3; K[32]:=B4; M[32]:=B5; end; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y[J]'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 2: GB2490; 4: begin GB2490; GB2500; end; 8: begin GB2490; GB2500; GB2510; end; 16: begin GB2490; GB2500; GB2510; GB2520; end; 32: begin GB2490; GB2500; GB2510; GB2520; GB2530; end; end;{case} GB780; case X of 4: GB810; 8: begin
112
GB810; GB850; end; 16: begin GB810; GB850; GB940; end; 32: begin GB810; GB850; GB940; GB1110; end; end;{case} writeln(' B(J) до анализа'); writeln(F0,' B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=5 then goto 5; if I0=30 then goto 3; if I0=25 then begin GB2820; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'N0-количество опытов на среднем уровне факторов'); writeln(F0,'N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов');
113
writeln(F0,'Ввод G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; writeln(F0,'S0=',S0); for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'U9-дисперсия опытов =',U9); end; if not(I0=5) then begin writeln(' Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'T-критерий T0=',T0); writeln(' B(J) после анализа'); writeln(F0,' B(J) после анализа'); for J:=1 to X do begin if T[J]
114
end; writeln('Количество статистически значимых'); writeln('коэффициентов регрессии'); writeln('K9=',K9); writeln('F9=X-1'); writeln(F0,'Количество статистически значимых'); writeln(F0,'коэффициентов регрессии'); writeln(F0,'K9=',K9); writeln(F0,'F9=X-1'); F9:=X-1; writeln('F9=',F9); writeln(F0,'F9=',F9); F9:=X-1; tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end;{case} writeln('Расчетные величины показателя'); writeln(' Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; if X=16 then begin writeln(F0,'X=16. System, 12.1 - 22.2, finish 32.2.'); writeln(F0,'12.1.','A1=',A1,'B3=',B3,'B4=',B4,'A2=',A2,'Z(13)=',Z[13]); writeln(F0,'12.2.','A1=',A1,'B3=',B3,'B4=',B4,'B2=',B2,'Z(15)=',Z[15]); writeln(F0,'13.1.','B1=',B1,'A3=',A3,'A4=',A4,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'13.2.','B1=',B1,'A3=',A3,'A4=',A4,'B2=',B2,'Z(4)=',Z[4]);
115
writeln(F0,'14.1.','B1=',B1,'B3=',B3,'A4=',A4,'A2=',A2,'Z(6)=',Z[6]); writeln(F0,'14.2.','B1=',B1,'B3=',B3,'A4=',A4,'B2=',B2,'Z(8)=',Z[8]); writeln(F0,'15.1.','B1=',B1,'A3=',A3,'B4=',B4,'A2=',A2,'Z(10)=',Z[10]); writeln(F0,'15.2.','B1=',B1,'A3=',A3,'B4=',B4,'B2=',B2,'Z(12)=',Z[12]); writeln(F0,'16.1.','B1=',B1,'B3=',B3,'B4=',B4,'A2=',A2,'Z(14)=',Z[14]); writeln(F0,'16.2.','B1=',B1,'B3=',B3,'B4=',B4,'B2=',B2,'Z(16)=',Z[16]); writeln(F0,'17.1.','A1=',A1,'A2=',A2,'A4=',A4,'A3=',A3,'Z(1)=',Z[1]); writeln(F0,'17.2.','A1=',A1,'A2=',A2,'A4=',A4,'B3=',B3,'Z(5)=',Z[5]); writeln(F0,'18.1.','A1=',A1,'B2=',B2,'A4=',A4,'A3=',A3,'Z(3)=',Z[3]); writeln(F0,'18.2.','A1=',A1,'B2=',B2,'A4=',A4,'B3=',B3,'Z(7)=',Z[7]); writeln(F0,'19.1.','A1=',A1,'A2=',A2,'B4=',B4,'A3=',A3,'Z(9)=',Z[9]); writeln(F0,'19.2.','A1=',A1,'A2=',A2,'B4=',B4,'B3=',B3,'Z(13)=',Z[13]); writeln(F0,'20.1.','A1=',A1,'B2=',B2,'B4=',B4,'A3=',A3,'Z(11)=',Z[11]); writeln(F0,'20.2.','A1=',A1,'B2=',B2,'B4=',B4,'B3=',B3,'Z(15)=',Z[15]); writeln(F0,'21.1.','B1=',B1,'A2=',A2,'A4=',A4,'A3=',A3,'Z(2)=',Z[2]); writeln(F0,'21.2.','B1=',B1,'A2=',A2,'A4=',A4,'B3=',B3,'Z(6)=',Z[6]); writeln(F0,'22.1.','B1=',B1,'B2=',B2,'A4=',A4,'A3=',A3,'Z(4)=',Z[4]); writeln(F0,'22.2.','B1=',B1,'B2=',B2,'A4=',A4,'B3=',B3,'Z(8)=',Z[8]); case X of 2: OUT_F_H_L(73); 4: OUT_F_H_L(74); 8: OUT_F_H_L(75); 16: OUT_F_H_L(76); 32: OUT_F_H_L(77); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB2820; goto 2; end; if I0=22 then begin GB7000; goto 5; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'Результаты расчетов по модели'); if X=2 then begin for S:=1 to X do begin
116
F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); GB2490; GB2540; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(73); end; if X=4 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,')'); readln(F[S],H[S]); GB2490; GB2500; GB2550; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(74); end; if X=8 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; L[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2570; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(75); end; if X=16 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; K[S]:=0; L[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,') K(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2520; GB2600; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(76); end; if X=32 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; L[S]:=0; K[S]:=0; M[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); writeln('Ввод K(',S,') M(',S,')'); readln(K[S],M[S]);
117
GB2490; GB2500; GB2510; GB2520; GB2530; GB2670; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(77); end; 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if (I0=11) then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end; end.{Конец программы} unit tpgl1_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6,Z2,Z3,Z4,Z5:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2,V4,V5,M3,M4:real; A4,B4,A5,B5,J4,T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0:TEXT; grMode: Integer; function ste(Q,A:real):real; procedure VVOD21; procedure VVOD22; procedure VVOD23; procedure VVOD24; procedure VVOD25; procedure GB780; procedure GB810; procedure GB850; procedure GB940; procedure GB1110; procedure GB2480(A,B,N:real; var V0:real); procedure GB2490; procedure GB2500; procedure GB2510; procedure GB2520; procedure GB2530; procedure GB2540; procedure GB2550; procedure GB2570; procedure GB2600; procedure GB2670;
118
Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then exit else begin if Q=0 then A:=1E-20; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure VVOD21; begin writeln('Ввод A1 B1 J1'); readln(A1,B1,J1); writeln(F0,'A1=',A1,' B1=',B1); writeln(F0,'J1=',J1); end; procedure VVOD22; begin writeln('Ввод A2 B2 J2'); readln(A2,B2,J2); writeln(F0,'A2=',A2,' B2=',B2); writeln(F0,'J2=',J2); end; procedure VVOD23; begin writeln('Ввод A3 B3 J3'); readln(A3,B3,J3); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD24; begin writeln('Ввод A4 B4 J4'); readln(A4,B4,J4); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD25; begin writeln('Ввод A5 B5 J5'); readln(A5,B5,J5); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure GB780; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1];
119
SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; end; procedure GB810; begin SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[3]:=O[3]+P[J]*P[J]; end; B[3]:=SS/O[3]; SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[4]:=O[4]+(I[J]*P[J])*(I[J]*P[J]); end; B[4]:=SS/O[4]; end;{GB810} procedure GB850; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[5]:=O[5]+U[J]*U[J]; end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[6]:=O[6]+(I[J]*U[J])*(I[J]*U[J]); end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[7]:=O[7]+(P[J]*U[J])*(P[J]*U[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[8]:=O[8]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[8]:=SS/O[8]; end;{GB850} procedure GB940;
120
begin SS:=0; O[9]:=0; for j:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[9]:=O[9]+Q[J]*Q[J]; end; B[9]:=SS/O[9]; SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[10]:=O[10]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*Y[J]; O[11]:=O[11]+(P[J]*Q[J])*(P[J]*Q[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Q[J]*Y[J]; O[12]:=O[12]+(I[J]*P[J]*Q[J])*(I[J]*P[J]*Q[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[13]:=O[13]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[14]:=O[14]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*Y[J]; O[15]:=O[15]+(P[J]*U[J]*Q[J])*(P[J]*U[J]*Q[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*Y[J]; O[16]:=O[16]+(I[J]*P[J]*U[J]*Q[J])*(I[J]*P[J]*U[J]*Q[J]); end; B[16]:=SS/O[16];
121
end;{GB940} procedure GB1110; begin SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[17]:=O[17]+V[J]*V[J]; end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[18]:=O[18]+(I[J]*V[J])*(I[J]*V[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[19]:=O[19]+(P[J]*V[J])*(P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[20]:=O[20]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+U[J]*V[J]*Y[J]; O[21]:=O[21]+(U[J]*V[J])*(U[J]*V[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*V[J]*Y[J]; O[22]:=O[22]+(I[J]*U[J]*V[J])*(I[J]*U[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*V[J]*Y[J]; O[23]:=O[23]+(P[J]*U[J]*V[J])*(P[J]*U[J]*V[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*P[J]*U[J]*V[J])*(I[J]*P[J]*U[J]*V[J]);
122
end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[25]:=O[25]+(Q[J]*V[J])*(Q[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[26]:=O[26]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*V[J]*Y[J]; O[27]:=O[27]+(P[J]*Q[J]*V[J])*(P[J]*Q[J]*V[J]); end; B[27]:=SS/O[27]; SS:=0; O[28]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Q[J]*V[J]*Y[J]; O[28]:=O[28]+(I[J]*P[J]*Q[J]*V[J])*(I[J]*P[J]*Q[J]*V[J]); end; B[28]:=SS/O[28]; SS:=0; O[29]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*V[J]*Y[J]; O[29]:=O[29]+(U[J]*Q[J]*V[J])*(U[J]*Q[J]*V[J]); end; B[29]:=SS/O[29]; SS:=0; O[30]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*V[J]*Y[J]; O[30]:=O[30]+(I[J]*U[J]*Q[J]*V[J])*(I[J]*U[J]*Q[J]*V[J]); end; B[30]:=SS/O[30]; SS:=0; O[31]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*V[J]*Y[J]; O[31]:=O[31]+(P[J]*U[J]*Q[J]*V[J])*(P[J]*U[J]*Q[J]*V[J]); end; B[31]:=SS/O[31]; SS:=0; O[32]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*V[J]*Y[J]; O[32]:=O[32]+(I[J]*P[J]*U[J]*Q[J]*V[J])* (I[J]*P[J]*U[J]*Q[J]*V[J]);
123
end; B[32]:=SS/O[32]; end;{GB1110} procedure GB2480(A,B,N:real; var V0:real); begin V0:=-(ste(A,N)+ste(B,N))/2; write('Коэффициент ортогонализации '); write(F0,'Коэффициент ортогонализации '); end;{GB2480} procedure GB2490; begin for J:=1 to X do I[J]:=ste(F[J],J1)+V1; end;{GB2490} procedure GB2500; begin for J:=1 to X do P[J]:=ste(H[J],J2)+V2; end;{GB2500} procedure GB2510; begin for J:=1 to X do U[J]:=ste(L[J],J3)+V3; end;{GB2510} procedure GB2520; begin for J:=1 to X do Q[J]:=ste(K[J],J4)+V4; end;{GB2520} procedure GB2530; begin for J:=1 to X do V[J]:=ste(M[J],J5)+V5; end;{GB2530} procedure GB2540; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]; end;{GB2540} procedure GB2550; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; end;{GB2550} procedure GB2570; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; Z[J]:=N3+N4+B[8]*I[J]*P[J]*U[J]; end; end;{GB2570} procedure GB2600; begin for J:=1 to X do begin
124
N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; Z[J]:=N3+N4+N5+N6+N7+B[16]*I[J]*P[J]*U[J]*Q[J]; end; end;{GB2600} procedure GB2670; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; R0:=B[16]*I[J]*P[J]*U[J]*Q[J]+B[17]*V[J]; R4:=B[18]*I[J]*V[J]+B[19]*P[J]*V[J]+B[20]*I[J]*P[J]*V[J]; R5:=B[21]*U[J]*V[J]+B[22]*I[J]*U[J]*V[J]; R6:=B[23]*P[J]*U[J]*V[J]+B[24]*I[J]*P[J]*U[J]*V[J]; Z2:=B[25]*Q[J]*V[J]+B[26]*I[J]*Q[J]*V[J]; Z3:=B[27]*P[J]*Q[J]*V[J]+B[28]*I[J]*P[J]*Q[J]*V[J]; Z4:=B[29]*U[J]*Q[J]*V[J]+B[30]*I[J]*U[J]*Q[J]*V[J]; Z5:=B[31]*P[J]*U[J]*Q[J]*V[J]+B[32]*I[J]*P[J]*U[J]*Q[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6+Z2+Z3+Z4+Z5; end; end;{GB2670} begin end.
125
Программа TNV5(два модуля tpgl3, 3-я часть, Х=2, Х=4, Х=8, _Х=16_, Х=32, «система» после «адекватно», 23.1-32.2)… program tpgl1_1; uses tpgl1_2; label 1,2,3,4,5; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значе'); writeln(F0,'ние │'); write(F0,'│ J ├──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │'); writeln(F0,' L(J) │ Z(J) │'); end; if PR=76 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'─────────────────────┐'); write(F0,'│ │ Значение '); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬──────────┬'); writeln(F0,'──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ Z(J) │'); end; if PR=77 then begin write(F0,'┌────┬─────────────────────────────────'); writeln(F0,'────────────────────────────────┐'); write(F0,'│ │ Зна'); writeln(F0,'чение │'); write(F0,'│ J ├──────────┬──────────┬─────────'); writeln(F0,'─┬──────────┬──────────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ L(J) │'); writeln(F0,' K(J) │ M(J) │ Z(J) │'); end;
126
if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│'); writeln(F0,H[J]:10,'│',L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; if PR=76 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',K[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end; if PR=77 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼────────'); writeln(F0,'──┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); write(F0,L[J]:10,'│',K[J]:10,'│',M[J]:10,'│'); writeln(F0,Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┴──────────┘'); end;
127
end;{OUT_F_H_L} procedure GB2820; begin writeln(F0,'Математическая модель'); if X=2 then begin writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J),'); end; if X=4 then begin writeln('Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J),'); end; if X=8 then begin writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J),'); end; if X=16 then begin writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J),'); end; if X=32 then begin writeln(F0,'Z(J)=',B[1],'+',B[2],'*I(J)+',B[3],'*P(J)+'); writeln(F0,'+',B[4],'*I(J)*P(J)+',B[5],'*U(J)+'); writeln(F0,'+',B[6],'*I(J)*U(J)+',B[7],'*P(J)*U(J)+'); writeln(F0,'+',B[8],'*I(J)*P(J)*U(J)+',B[9],'*Q(J)+'); writeln(F0,'+',B[10],'*I(J)*Q(J)+',B[11],'*P(J)*Q(J)+'); writeln(F0,'+',B[12],'*I(J)*P(J)*Q(J)+',B[13],'*U(J)*Q(J)+'); writeln(F0,'+',B[14],'I(J)*U(J)*Q(J)+',B[15],'*P(J)*U(J)*Q(J)+'); writeln(F0,'+',B[16],'I(J)*P(J)*U(J)*Q(J)+',B[17],'*V(J)+'); writeln(F0,'+',B[18],'*I(J)*V(J)+',B[19],'P(J)*V(J)+'); writeln(F0,'+',B[20],'*I(J)*P(J)*V(J)+',B[21],'*U(J)*V(J)+'); writeln(F0,'+',B[22],'*I(J)*U(J)*V(J)+',B[23],'*P(J)*U(J)*V(J)+'); writeln(F0,'+',B[24],'*I(J)*P(J)*U(J)*V(J)+',B[25],'*Q(J)*V(J)+'); writeln(F0,'+',B[26],'*I(J)*Q(J)*V(J)+',B[27],'*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[28],'*I(J)*P(J)*Q(J)*V(J)+'); writeln(F0,'+',B[29],'*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[30],'*I(J)*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[31],'*P(J)*U(J)*Q(J)*V(J)+'); writeln(F0,'+',B[32],'*I(J)*P(J)*U(J)*Q(J)*V(J),'); end; if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1,'+',V1); writeln(F0,'Обозначение:F(J)- 1-ый фактор ');
128
end; if (X=4)or(X=8)or(X=16)or(X=32) then begin writeln(F0,'P(J)=H(J)^',J2,'+',V2); writeln(F0,'Обозначение:H(J)- 2-ой фактор'); end; if (X=8)or(X=16)or(X=32) then begin writeln(F0,'U(J)=L(J)^',J3,'+',V3); writeln(F0,'Обозначение:L(J)- 3-ий фактор'); end; if (X=16)or(X=32) then begin writeln(F0,'Q(J)=K(J)^',J4,'+',V4); writeln(F0,'Обозначение:K(J)- 4-ый фактор'); end; if (X=32) then begin writeln(F0,'V(J)=M(J)^',J5,'+',V5); writeln(F0,'Обозначение:M(J)- 5-ый фактор'); end; end;{GB2820} procedure GB7000; label 1; begin repeat writeln('Вычисления показателей Z(K5)'); writeln(' по математической модели'); writeln(' с ипользованием циклов'); writeln('vvod X'); write('X='); readln(X); writeln(F0,'Вычисления показателей Z(K5)'); writeln(F0,' по математической модели'); writeln(F0,' с ипользованием циклов'); writeln(F0,'X=',X); case X of 2: I0:=73; 4: I0:=74; 8: I0:=75; 16: I0:=76; 32: I0:=77; end; if I0=73 then begin F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'Ввод принятых величин X F3 F4');
129
readln(X,F3,F4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end; GB2490; GB2540; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=74 then begin F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); end; GB2490; GB2500; GB2550; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=75 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора');
130
writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); end; GB2490; GB2500; GB2510; GB2570; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=76 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln('X-количество значений 1,2,3,4-го фактора'); writeln(F0,'F4,H4,L4,K4-шаг приращения 1,2,3,4-го фактора'); writeln(F0,'X-количество значений 1,2,3,4-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4;
131
writeln('K(',K5,')=',K[K5]); end; GB2490; GB2500;GB2510; GB2520; GB2600; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} if I0=77 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; K3:=0; K4:=0; M3:=0; M4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln('Факторы K(1)=K3+K4, M(1)=M3+M4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы K(1)=K3+K4, M(1)=M3+M4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; K[J]:=0; M[J]:=0; Z[J]:=0; end; writeln('F4,H4,L4,K4,M4-шаг приращения 1,2,3,4,5-го фактора'); writeln('X-количество значений 1,2,3,4,5-го фактора'); write(F0,'F4,H4,L4,K4,M4-шаг приращения'); writeln(F0,' 1,2,3,4,5-го фактора'); writeln(F0,'X-количество значений 1,2,3,4,5-го фактора'); writeln('Ввод принятых величин'); writeln('X F3 F4 H3 H4 L3 L4 K3 K4 M3 M4'); readln(X,F3,F4,H3,H4,L3,L4,K3,K4,M3,M4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); writeln(F0,'K3=',K3,' K4=',K4); writeln(F0,'M3=',M3,' M4=',M4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); K[K5]:=K3+K5*K4; writeln('K(',K5,')=',K[K5]); M[K5]:=M3+K5*M4; writeln('M(',K5,')=',M[K5]); end; GB2490; GB2500; GB2510; GB2520; GB2530; GB2670; for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(I0); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); K8:=0; K8:=Z[1]; for K5:=1 to X do
132
if Z[K5]>=K8 then K8:=Z[K5]; writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; begin writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); end; for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика, Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94, то выход '); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000} procedure tablF9; begin writeln('Значения F7 для 5% уровня знач-ти'); writeln('┌───┬───────────────────────────┐'); writeln('│ │ F9 │'); writeln('│F8 ├────┬─────┬─────┬─────┬────┤'); writeln('│ │ 1 │ 3 │ 7 │ 15 │ 31 │');
133
writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 2 │19.0│19.16│19.36│19.42│9.46│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 3 │9.55│ 9.28│ 8.88│ 8.71│8.62│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 4 │6.94│ 6.59│ 6.09│ 5.87│5.74│'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 5 │5.79│ 5.41│ 4.88│ 4.64│4.5 │'); writeln('├───┼────┼─────┼─────┼─────┼────┤'); writeln('│ 6 │5.14│ 4.76│ 4.21│ 3.96│3.81│'); writeln('└───┴────┴─────┴─────┴─────┴────┘'); end; procedure OUT_Z_B; begin writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); writeln('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│', (Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {========================Основная программа=======================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из двух'); writeln(' файлов tpgl1_1, tpl1_2(tnv5_1,tnv5_2). Математическое'); writeln(' моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программ GGL3,NV1.'); writeln(' Разработка Черного А.А.'); writeln(' Author Chernyy Anatoly Alekseevech.'); writeln(' Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,' Выполнение программы математического моделирования'); writeln(F0,' tpgl1_1(tnv5_1). Программа на языке Турбо-Паскаль,'); writeln(F0,' X=2, X=4, X=8, _X=16_, X=32.'); writeln(' X=2, X=4, X=8, _X=16_, X=32.'); writeln(F0,' Author Chernyy Anatoly Alekseevech.'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin
134
F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; case X of 2: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); end; 4: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); end; 8: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); end; 16: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1); writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24; GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); end; 32: begin vvod21; GB2480(A1,B1,J1,V1); writeln(F0,'V1=',V1);
135
writeln('V1=',V1); vvod22; GB2480(A2,B2,J2,V2); writeln(F0,'V2=',V2); writeln('V2=',V2); vvod23; GB2480(A3,B3,J3,V3); writeln(F0,'V3=',V3); writeln('V3=',V3); vvod24; GB2480(A4,B4,J4,V4); writeln(F0,'V4=',V4); writeln('V4=',V4); vvod25; GB2480(A5,B5,J5,V5); writeln(F0,'V5=',V5); writeln('V5=',V5); end; 0: goto 2; else goto 2; end;{case} if (X=2)or(X=4)or(X=8)or(X=16)or(X=32) then begin F[1]:=A1; F[2]:=B1; end; if (X=4)or(X=8)or(X=16)or(X=32) then begin H[1]:=A2; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; end; if (X=8)or(X=16)or(X=32) then begin L[1]:=A3; L[2]:=A3; L[3]:=A3; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; end; if (X=16)or(X=32) then begin K[1]:=A4; K[2]:=A4; K[3]:=A4; K[4]:=A4; K[5]:=A4; K[6]:=A4; K[7]:=A4; K[8]:=A4; F[9]:=A1; H[9]:=A2; L[9]:=A3; K[9]:=B4; F[10]:=B1; H[10]:=A2; L[10]:=A3; K[10]:=B4; F[11]:=A1; H[11]:=B2; L[11]:=A3; K[11]:=B4; F[12]:=B1; H[12]:=B2; L[12]:=A3; K[12]:=B4; F[13]:=A1; H[13]:=A2; L[13]:=B3; K[13]:=B4; F[14]:=B1; H[14]:=A2; L[14]:=B3; K[14]:=B4; F[15]:=A1; H[15]:=B2; L[15]:=B3; K[15]:=B4; F[16]:=B1; H[16]:=B2; L[16]:=B3; K[16]:=B4; end; if X=32 then begin M[1]:=A5; M[2]:=A5; M[3]:=A5; M[4]:=A5; M[5]:=A5; M[6]:=A5; M[7]:=A5; M[8]:=A5; M[9]:=A5; M[10]:=A5; M[11]:=A5; M[12]:=A5; M[13]:=A5; M[14]:=A5; M[15]:=A5; M[16]:=A5; F[17]:=A1; H[17]:=A2; L[17]:=A3; K[17]:=A4; M[17]:=B5; F[18]:=B1; H[18]:=A2; L[18]:=A3; K[18]:=A4; M[18]:=B5; F[19]:=A1; H[19]:=B2; L[19]:=A3; K[19]:=A4; M[19]:=B5; F[20]:=B1; H[20]:=B2; L[20]:=A3; K[20]:=A4;
136
M[20]:=B5; F[21]:=A1; H[21]:=A2; L[21]:=B3; K[21]:=A4; M[21]:=B5; F[22]:=B1; H[22]:=A2; L[22]:=B3; K[22]:=A4; M[22]:=B5; F[23]:=A1; H[23]:=B2; L[23]:=B3; K[23]:=A4; M[23]:=B5; F[24]:=B1; H[24]:=B2; L[24]:=B3; K[24]:=A4; M[24]:=B5; F[25]:=A1; H[25]:=A2; L[25]:=A3; K[25]:=B4; M[25]:=B5; F[26]:=B1; H[26]:=A2; L[26]:=A3; K[26]:=B4; M[26]:=B5; F[27]:=A1; H[27]:=B2; L[27]:=A3; K[27]:=B4; M[27]:=B5; F[28]:=B1; H[28]:=B2; L[28]:=A3; K[28]:=B4; M[28]:=B5; F[29]:=A1; H[29]:=A2; L[29]:=B3; K[29]:=B4; M[29]:=B5; F[30]:=B1; H[30]:=A2; L[30]:=B3; K[30]:=B4; M[30]:=B5; F[31]:=A1; H[31]:=B2; L[31]:=B3; K[31]:=B4; M[31]:=B5; F[32]:=B1; H[32]:=B2; L[32]:=B3; K[32]:=B4; M[32]:=B5; end; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y[J]'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 2: GB2490; 4: begin GB2490; GB2500; end; 8: begin GB2490; GB2500; GB2510; end; 16: begin GB2490; GB2500; GB2510; GB2520; end; 32: begin GB2490; GB2500; GB2510; GB2520; GB2530; end; end;{case} GB780; case X of 4: GB810; 8: begin GB810; GB850; end; 16: begin GB810; GB850; GB940; end; 32: begin GB810; GB850; GB940; GB1110; end; end;{case}
137
writeln(' B(J) до анализа'); writeln(F0,' B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=5 then goto 5; if I0=30 then goto 3; if I0=25 then begin GB2820; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'N0-количество опытов на среднем уровне факторов'); writeln(F0,'N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'Ввод G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0;
138
for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; writeln(F0,'S0=',S0); for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'U9-дисперсия опытов =',U9); end; if not(I0=5) then begin writeln(' Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'T-критерий T0=',T0); writeln(' B(J) после анализа'); writeln(F0,' B(J) после анализа'); for J:=1 to X do begin if T[J]
139
F9:=X-1; writeln('F9=',F9); writeln(F0,'F9=',F9); F9:=X-1; tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 2: GB2540; 4: GB2550; 8: GB2570; 16: GB2600; 32: GB2670; end;{case} writeln('Расчетные величины показателя'); writeln(' Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; if X=16 then begin writeln(F0,'X=16. System, 23.1 - 32.2, finish 32.2.'); writeln(F0,'23.1.','B1=',B1,'A2=',A2,'B4=',B4,'A3=',A3,'Z(10)=',Z[10]); writeln(F0,'23.2.','B1=',B1,'A2=',A2,'B4=',B4,'B3=',B3,'Z(14)=',Z[14]); writeln(F0,'24.1.','B1=',B1,'B2=',B2,'B4=',B4,'A3=',A3,'Z(12)=',Z[12]); writeln(F0,'24.2.','B1=',B1,'B2=',B2,'B4=',B4,'B3=',B3,'Z(16)=',Z[16]); writeln(F0,'25.1.','A2=',A2,'A3=',A3,'A1=',A1,'A4=',A4,'Z(1)=',Z[1]); writeln(F0,'25.2.','A2=',A2,'A3=',A3,'A1=',A1,'B4=',B4,'Z(9)=',Z[9]); writeln(F0,'26.1.','A2=',A2,'B3=',B3,'A1=',A1,'A4=',A4,'Z(5)=',Z[5]); writeln(F0,'26.2.','A2=',A2,'B3=',B3,'A1=',A1,'B4=',B4,'Z(13)=',Z[13]); writeln(F0,'27.1.','A2=',A2,'A3=',A3,'B1=',B1,'A4=',A4,'Z(2)=',Z[2]); writeln(F0,'27.2.','A2=',A2,'A3=',A3,'B1=',B1,'B4=',B4,'Z(10)=',Z[10]); writeln(F0,'28.1.','A2=',A2,'B3=',B3,'B1=',B1,'A4=',A4,'Z(6)=',Z[6]); writeln(F0,'28.2.','A2=',A2,'B3=',B3,'B1=',B1,'B4=',B4,'Z(14)=',Z[14]); writeln(F0,'29.1.','B2=',B2,'A3=',A3,'A1=',A1,'A4=',A4,'Z(3)=',Z[3]);
140
writeln(F0,'29.2.','B2=',B2,'A3=',A3,'A1=',A1,'B4=',B4,'Z(11)=',Z[11]); writeln(F0,'30.1.','B2=',B2,'B3=',B3,'A1=',A1,'A4=',A4,'Z(7)=',Z[7]); writeln(F0,'30.2.','B2=',B2,'B3=',B3,'A1=',A1,'B4=',B4,'Z(15)=',Z[15]); writeln(F0,'31.1.','B2=',B2,'A3=',A3,'B1=',B1,'A4=',A4,'Z(4)=',Z[4]); writeln(F0,'31.2.','B2=',B2,'A3=',A3,'B1=',B1,'B4=',B4,'Z(12)=',Z[12]); writeln(F0,'32.1.','B2=',B2,'B3=',B3,'B1=',B1,'A4=',A4,'Z(8)=',Z[8]); writeln(F0,'32.2.','B2=',B2,'B3=',B3,'B1=',B1,'B4=',B4,'Z(16)=',Z[16]); end; case X of 2: OUT_F_H_L(73); 4: OUT_F_H_L(74); 8: OUT_F_H_L(75); 16: OUT_F_H_L(76); 32: OUT_F_H_L(77); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB2820; goto 2; end; if I0=22 then begin GB7000; goto 5; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S), K(S), M(S) - 1,2,3,4,5 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'Результаты расчетов по модели'); if X=2 then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); GB2490; GB2540; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(73); end; if X=4 then begin
141
for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,')'); readln(F[S],H[S]); GB2490; GB2500; GB2550; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(74); end; if X=8 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; Z[S]:=0; L[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2570; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(75); end; if X=16 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; K[S]:=0; L[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,') K(',S,')'); readln(F[S],H[S],L[S]); GB2490; GB2500; GB2510; GB2520; GB2600; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(76); end; if X=32 then begin for S:=1 to X do begin F[S]:=0; H[S]:=0; L[S]:=0; K[S]:=0; M[S]:=0; Z[S]:=0; writeln('Ввод F(',S,') H(',S,') L(',S,')'); readln(F[S],H[S],L[S]); writeln('Ввод K(',S,') M(',S,')'); readln(K[S],M[S]); GB2490; GB2500; GB2510; GB2520; GB2530; GB2670; writeln('Z(',S,')=',Z[S]); end; OUT_F_H_L(77); end; 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления ');
142
writeln('показателей Z(K5) с использованием'); writeln('циклов и построение графиков'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if (I0=11) then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end.{Конец программы} unit tpgl1_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6,Z2,Z3,Z4,Z5:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2,V4,V5,M3,M4:real; A4,B4,A5,B5,J4,T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0:TEXT; grDriver,grMode: Integer; function ste(Q,A:real):real; procedure VVOD21; procedure VVOD22; procedure VVOD23; procedure VVOD24; procedure VVOD25; procedure GB780; procedure GB810; procedure GB850; procedure GB940; procedure GB1110; procedure GB2480(A,B,N:real; var V0:real); procedure GB2490; procedure GB2500; procedure GB2510; procedure GB2520; procedure GB2530; procedure GB2540; procedure GB2550; procedure GB2570; procedure GB2600; procedure GB2670; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then exit else begin if Q=0 then A:=1E-20; if A=0 then ste:=1 else ste:=exp(A*ln(Q));
143
end; end;{ste} procedure VVOD21; begin writeln('Ввод A1 B1 J1'); readln(A1,B1,J1); writeln(F0,'A1=',A1,' B1=',B1); writeln(F0,'J1=',J1); end; procedure VVOD22; begin writeln('Ввод A2 B2 J2'); readln(A2,B2,J2); writeln(F0,'A2=',A2,' B2=',B2); writeln(F0,'J2=',J2); end; procedure VVOD23; begin writeln('Ввод A3 B3 J3'); readln(A3,B3,J3); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD24; begin writeln('Ввод A4 B4 J4'); readln(A4,B4,J4); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure VVOD25; begin writeln('Ввод A5 B5 J5'); readln(A5,B5,J5); writeln(F0,'A3=',A3,' B3=',B3); writeln(F0,'J3=',J3); end; procedure GB780; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; end; procedure GB810; begin SS:=0; O[3]:=0;
144
for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[3]:=O[3]+P[J]*P[J]; end; B[3]:=SS/O[3]; SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[4]:=O[4]+(I[J]*P[J])*(I[J]*P[J]); end; B[4]:=SS/O[4]; end;{GB810} procedure GB850; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[5]:=O[5]+U[J]*U[J]; end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[6]:=O[6]+(I[J]*U[J])*(I[J]*U[J]); end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[7]:=O[7]+(P[J]*U[J])*(P[J]*U[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[8]:=O[8]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[8]:=SS/O[8]; end;{GB850} procedure GB940; begin SS:=0; O[9]:=0; for j:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[9]:=O[9]+Q[J]*Q[J]; end; B[9]:=SS/O[9]; SS:=0; O[10]:=0; for J:=1 to X do begin
145
SS:=SS+I[J]*Q[J]*Y[J]; O[10]:=O[10]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*Y[J]; O[11]:=O[11]+(P[J]*Q[J])*(P[J]*Q[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Q[J]*Y[J]; O[12]:=O[12]+(I[J]*P[J]*Q[J])*(I[J]*P[J]*Q[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[13]:=O[13]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[14]:=O[14]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*Y[J]; O[15]:=O[15]+(P[J]*U[J]*Q[J])*(P[J]*U[J]*Q[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*Y[J]; O[16]:=O[16]+(I[J]*P[J]*U[J]*Q[J])*(I[J]*P[J]*U[J]*Q[J]); end; B[16]:=SS/O[16]; end;{GB940} procedure GB1110; begin SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[17]:=O[17]+V[J]*V[J]; end; B[17]:=SS/O[17]; SS:=0; O[18]:=0;
146
for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[18]:=O[18]+(I[J]*V[J])*(I[J]*V[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[19]:=O[19]+(P[J]*V[J])*(P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[20]:=O[20]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+U[J]*V[J]*Y[J]; O[21]:=O[21]+(U[J]*V[J])*(U[J]*V[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*V[J]*Y[J]; O[22]:=O[22]+(I[J]*U[J]*V[J])*(I[J]*U[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*V[J]*Y[J]; O[23]:=O[23]+(P[J]*U[J]*V[J])*(P[J]*U[J]*V[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*P[J]*U[J]*V[J])*(I[J]*P[J]*U[J]*V[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[25]:=O[25]+(Q[J]*V[J])*(Q[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do
147
begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[26]:=O[26]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin SS:=SS+P[J]*Q[J]*V[J]*Y[J]; O[27]:=O[27]+(P[J]*Q[J]*V[J])*(P[J]*Q[J]*V[J]); end; B[27]:=SS/O[27]; SS:=0; O[28]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Q[J]*V[J]*Y[J]; O[28]:=O[28]+(I[J]*P[J]*Q[J]*V[J])*(I[J]*P[J]*Q[J]*V[J]); end; B[28]:=SS/O[28]; SS:=0; O[29]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*V[J]*Y[J]; O[29]:=O[29]+(U[J]*Q[J]*V[J])*(U[J]*Q[J]*V[J]); end; B[29]:=SS/O[29]; SS:=0; O[30]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*V[J]*Y[J]; O[30]:=O[30]+(I[J]*U[J]*Q[J]*V[J])*(I[J]*U[J]*Q[J]*V[J]); end; B[30]:=SS/O[30]; SS:=0; O[31]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Q[J]*V[J]*Y[J]; O[31]:=O[31]+(P[J]*U[J]*Q[J]*V[J])*(P[J]*U[J]*Q[J]*V[J]); end; B[31]:=SS/O[31]; SS:=0; O[32]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Q[J]*V[J]*Y[J]; O[32]:=O[32]+(I[J]*P[J]*U[J]*Q[J]*V[J])* (I[J]*P[J]*U[J]*Q[J]*V[J]); end; B[32]:=SS/O[32]; end;{GB1110} procedure GB2480(A,B,N:real; var V0:real); begin V0:=-(ste(A,N)+ste(B,N))/2; write('Коэффициент ортогонализации '); write(F0,'Коэффициент ортогонализации '); end;{GB2480} procedure GB2490; begin
148
for J:=1 to X do I[J]:=ste(F[J],J1)+V1; end;{GB2490} procedure GB2500; begin for J:=1 to X do P[J]:=ste(H[J],J2)+V2; end;{GB2500} procedure GB2510; begin for J:=1 to X do U[J]:=ste(L[J],J3)+V3; end;{GB2510} procedure GB2520; begin for J:=1 to X do Q[J]:=ste(K[J],J4)+V4; end;{GB2520} procedure GB2530; begin for J:=1 to X do V[J]:=ste(M[J],J5)+V5; end;{GB2530} procedure GB2540; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]; end;{GB2540} procedure GB2550; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; end;{GB2550} procedure GB2570; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; Z[J]:=N3+N4+B[8]*I[J]*P[J]*U[J]; end; end;{GB2570} procedure GB2600; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; Z[J]:=N3+N4+N5+N6+N7+B[16]*I[J]*P[J]*U[J]*Q[J]; end; end;{GB2600} procedure GB2670; begin for J:=1 to X do
149
begin N3:=B[1]+B[2]*I[J]+B[3]*P[J]+B[4]*I[J]*P[J]; N4:=B[5]*U[J]+B[6]*I[J]*U[J]+B[7]*P[J]*U[J]; N5:=B[8]*I[J]*P[J]*U[J]+B[9]*Q[J]+B[10]*I[J]*Q[J]; N6:=B[11]*P[J]*Q[J]+B[12]*I[J]*P[J]*Q[J]+B[13]*U[J]*Q[J]; N7:=B[14]*I[J]*U[J]*Q[J]+B[15]*P[J]*U[J]*Q[J]; R0:=B[16]*I[J]*P[J]*U[J]*Q[J]+B[17]*V[J]; R4:=B[18]*I[J]*V[J]+B[19]*P[J]*V[J]+B[20]*I[J]*P[J]*V[J]; R5:=B[21]*U[J]*V[J]+B[22]*I[J]*U[J]*V[J]; R6:=B[23]*P[J]*U[J]*V[J]+B[24]*I[J]*P[J]*U[J]*V[J]; Z2:=B[25]*Q[J]*V[J]+B[26]*I[J]*Q[J]*V[J]; Z3:=B[27]*P[J]*Q[J]*V[J]+B[28]*I[J]*P[J]*Q[J]*V[J]; Z4:=B[29]*U[J]*Q[J]*V[J]+B[30]*I[J]*U[J]*Q[J]*V[J]; Z5:=B[31]*P[J]*U[J]*Q[J]*V[J]+B[32]*I[J]*P[J]*U[J]*Q[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6+Z2+Z3+Z4+Z5; end; end;{GB2670} begin end.
150
Программа NW3(три модуля tpg3, 1-я часть, _Х=3_, _Х=9_, _Х=27_, «система» после «адекватно», 1.1-18.3)… program tpg3_1; {Математическое моделирование} uses tpg3_3, tpg3_2; label 1,2,3,4,5; procedure VV_DAN; begin case X of 3: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); end; 9: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); end; 27:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); VVOD33; GB3660(A3,E3,B3,J3,O3,V3,U3,Q3); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V3=',V3,' U3=',U3,' Q3=',Q3); writeln(F0,'V3=',V3,' U3=',U3,' Q3=',Q3); end; end;{case} end;{VV_DAN} procedure OUT_Z_B;
151
begin writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln(F0,(Y[J]-Z[J]):10,'│'); write('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln((Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {================================================================ Основная программа =================================================================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из трех'); writeln('файлов tpg3_1,tpg3_2,tpg3_3(nw3_1,nw3_2,nw3_3). Математическое'); writeln(' моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программы GGN3.'); writeln(' Разработка Черного А.А.'); writeln(' Autor Chernyy Anatoly Alekseevech'); writeln('Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,'Выполнение программы математического моделирования'); writeln(F0,' tpg3_1 (nw3_1). (Программа на языке Турбо-Паскаль).'); writeln(F0,' Autor Chernyy Anatoly Alekseevech'); writeln('_X=3_,X=9_,_X=27_'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; VV_DAN; if X=0 then goto 2; PR_MOD; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение и'); writeln('ввод величин показателей Y(J)'); write('I0='); readln(I0);
152
if I0=6 then goto 1; writeln('Ввод величин показателей Y(J)'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 3: GB4150; 9: begin GB4150; GB4170; end; 27:begin GB4150; GB4170; GB4190; end; end;{case} GB1410; case X of 9: begin GB1480; end; 27:begin GB1480; GB2040; end; end; writeln('B(J) до анализа'); writeln(F0,'B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 3: GB4390; 9: GB4450; 27:GB4770; else goto 2; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=30 then goto 3; if I0=25 then begin GB4880; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin
153
writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'Количество опытов на среднем уровне факторов N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if not(I0=5) then begin writeln('Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'Табличный T-критерий T0=',T0:5:3); writeln('B(J) после анализа'); writeln(F0,'B(J) после анализа');
154
for J:=1 to X do begin if T[J]F7 then begin writeln('Неадекватно, так как F6>F7');
155
writeln(F0,'Неадекватно, так как F6>F7'); end; if X=3 then begin writeln(F0,'X=3. System, 1.1 - 1.3, finish 1.3.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','E1=',E1,'Z(3)=',Z[3]); writeln(F0,'1.3.','B1=',B1,'Z(2)=',Z[2]); end; if X=9 then begin writeln(F0,'X=9. System, 1.1 - 6.3, finish 6.3.'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'E1=',E1,'Z(7)=',Z[7]); writeln(F0,'1.3.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','E2=',E2,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'2.2.','E2=',E2,'E1=',E1,'Z(9)=',Z[9]); writeln(F0,'2.3.','E2=',E2,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'3.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'3.2.','B2=',B2,'E1=',E1,'Z(8)=',Z[8]); writeln(F0,'3.3.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'4.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'4.2.','A1=',A1,'E2=',E2,'Z(5)=',Z[5]); writeln(F0,'4.3.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'5.1.','E1=',E1,'A2=',A2,'Z(7)=',Z[7]); writeln(F0,'5.2.','E1=',E1,'E2=',E2,'Z(9)=',Z[9]); writeln(F0,'5.3.','E1=',E1,'B2=',B2,'Z(8)=',Z[8]); writeln(F0,'6.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'6.2.','B1=',B1,'E2=',E2,'Z(6)=',Z[6]); writeln(F0,'6.3.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); end; if X=27 then begin writeln(F0,'X=27. System, 1.1 - 18.3, finish 27.3.'); writeln(F0,'1.1.','A2=',A2,'A3=',A3,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'A3=',A3,'E1=',E1,'Z(23)=',Z[23]); writeln(F0,'1.3.','A2=',A2,'A3=',A3,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','A2=',A2,'E3=',E3,'A1=',A1,'Z(15)=',Z[15]); writeln(F0,'2.2.','A2=',A2,'E3=',E3,'E1=',E1,'Z(11)=',Z[11]); writeln(F0,'2.3.','A2=',A2,'E3=',E3,'B1=',B1,'Z(16)=',Z[16]); writeln(F0,'3.1.','A2=',A2,'B3=',B3,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'3.2.','A2=',A2,'B3=',B3,'E1=',E1,'Z(25)=',Z[25]); writeln(F0,'3.3.','A2=',A2,'B3=',B3,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'4.1.','E2=',E2,'A3=',A3,'A1=',A1,'Z(19)=',Z[19]); writeln(F0,'4.2.','E2=',E2,'A3=',A3,'E1=',E1,'Z(13)=',Z[13]); writeln(F0,'4.3.','E2=',E2,'A3=',A3,'B1=',B1,'Z(20)=',Z[20]); writeln(F0,'5.1.','E2=',E2,'E3=',E3,'A1=',A1,'Z(9)=',Z[9]); writeln(F0,'5.2.','E2=',E2,'E3=',E3,'E1=',E1,'Z(27)=',Z[27]); writeln(F0,'5.3.','E2=',E2,'E3=',E3,'B1=',B1,'Z(10)=',Z[10]); writeln(F0,'6.1.','E2=',E2,'B3=',B3,'A1=',A1,'Z(21)=',Z[21]); writeln(F0,'6.2.','E2=',E2,'B3=',B3,'E1=',E1,'Z(14)=',Z[14]); writeln(F0,'6.3.','E2=',E2,'B3=',B3,'B1=',B1,'Z(22)=',Z[22]); writeln(F0,'7.1.','B2=',B2,'A3=',A3,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'7.2.','B2=',B2,'A3=',A3,'E1=',E1,'Z(24)=',Z[24]); writeln(F0,'7.3.','B2=',B2,'A3=',A3,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'8.1.','B2=',B2,'E3=',E3,'A1=',A1,'Z(17)=',Z[17]); writeln(F0,'8.2.','B2=',B2,'E3=',E3,'E1=',E1,'Z(12)=',Z[12]);
156
writeln(F0,'8.3.','B2=',B2,'E3=',E3,'B1=',B1,'Z(18)=',Z[18]); writeln(F0,'9.1.','B2=',B2,'B3=',B3,'A1=',A1,'Z(7)=',Z[7]); writeln(F0,'9.2.','B2=',B2,'B3=',B3,'E1=',E1,'Z(26)=',Z[26]); writeln(F0,'9.3.','B2=',B2,'B3=',B3,'B1=',B1,'Z(8)=',Z[8]); writeln(F0,'10.1.','A3=',A3,'A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'10.2.','A3=',A3,'A1=',A1,'E2=',E2,'Z(19)=',Z[19]); writeln(F0,'10.3.','A3=',A3,'A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'11.1.','A3=',A3,'E1=',E1,'A2=',A2,'Z(23)=',Z[23]); writeln(F0,'11.2.','A3=',A3,'E1=',E1,'E2=',E2,'Z(13)=',Z[13]); writeln(F0,'11.3.','A3=',A3,'E1=',E1,'B2=',B2,'Z(24)=',Z[24]); writeln(F0,'12.1.','A3=',A3,'B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'12.2.','A3=',A3,'B1=',B1,'E2=',E2,'Z(20)=',Z[20]); writeln(F0,'12.3.','A3=',A3,'B1=',B1,'B2=',B2,'Z(4)=',Z[4]); writeln(F0,'13.1.','E3=',E3,'A1=',A1,'A2=',A2,'Z(15)=',Z[15]); writeln(F0,'13.2.','E3=',E3,'A1=',A1,'E2=',E2,'Z(9)=',Z[9]); writeln(F0,'13.3.','E3=',E3,'A1=',A1,'B2=',B2,'Z(17)=',Z[17]); writeln(F0,'14.1.','E3=',E3,'E1=',E1,'A2=',A2,'Z(11)=',Z[11]); writeln(F0,'14.2.','E3=',E3,'E1=',E1,'E2=',E2,'Z(27)=',Z[27]); writeln(F0,'14.3.','E3=',E3,'E1=',E1,'B2=',B2,'Z(12)=',Z[12]); writeln(F0,'15.1.','E3=',E3,'B1=',B1,'A2=',A2,'Z(16)=',Z[16]); writeln(F0,'15.2.','E3=',E3,'B1=',B1,'E2=',E2,'Z(10)=',Z[10]); writeln(F0,'15.3.','E3=',E3,'B1=',B1,'B2=',B2,'Z(18)=',Z[18]); writeln(F0,'16.1.','B3=',B3,'A1=',A1,'A2=',A2,'Z(5)=',Z[5]); writeln(F0,'16.2.','B3=',B3,'A1=',A1,'E2=',E2,'Z(21)=',Z[21]); writeln(F0,'16.3.','B3=',B3,'A1=',A1,'B2=',B2,'Z(7)=',Z[7]); writeln(F0,'17.1.','B3=',B3,'E1=',E1,'A2=',A2,'Z(25)=',Z[25]); writeln(F0,'17.2.','B3=',B3,'E1=',E1,'E2=',E2,'Z(14)=',Z[14]); writeln(F0,'17.3.','B3=',B3,'E1=',E1,'B2=',B2,'Z(26)=',Z[26]); writeln(F0,'18.1.','B3=',B3,'B1=',B1,'A2=',A2,'Z(6)=',Z[6]); writeln(F0,'18.2.','B3=',B3,'B1=',B1,'E2=',E2,'Z(22)=',Z[22]); writeln(F0,'18.3.','B3=',B3,'B1=',B1,'B2=',B2,'Z(8)=',Z[8]); end; case X of 3: OUT_F_H_L(73); 9: OUT_F_H_L(74); 27:OUT_F_H_L(75); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB4880; goto 2; end; if I0=22 then begin GB7000; goto 2; end;
157
writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S) - 1,2,3 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S) - 1,2,3 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'расчеты по модели'); if (X=3)or(X=4)or(X=5)then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); case X of 3: begin GB4150; GB4390; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(73); end;{if} if (X=9) then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; H[S]:=0; writeln('Ввод F(',S,')',' H(',S,')'); readln(F[S],H[S]); case X of 9: begin GB4150; GB4170; GB4450; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(74); end;{if} if X=27 then begin for S:=1 to X do begin writeln('Ввод F(',S,')',' H(',S,')',' L(',S,')'); readln(F[S],H[S],L[S]); GB4150; GB4170; GB4190; GB4770; writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(75); end;{if} 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления ');
158
writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if I0=11 then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end.{Конец программы} unit TPG3_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2:real; T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0: Text; procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); function ste(Q,A:real):real; procedure GB1410; procedure GB1480; procedure GB2040; procedure GB4150; procedure GB4170; procedure GB4190; procedure GB4450; procedure GB4390; procedure GB4770; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then begin A:=abs(A); if Q=0 then Q:=1E-5; ste:=1/exp(A*ln(Q)); end else begin if Q=0 then Q:=1E-5; if A=0 then ste:=1
159
else ste:=exp(A*ln(Q)); end; end;{ste} procedure GB1410; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+K[J]*Y[J]; O[3]:=O[3]+K[J]*K[J]; end; B[3]:=SS/O[3]; end;{GB1410} procedure GB1480; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[4]:=O[4]+P[J]*P[J]; end; B[4]:=SS/O[4]; SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[5]:=O[5]+(I[J]*P[J])*(I[J]*P[J]); end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[6]:=O[6]+Q[J]*Q[J]; end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[7]:=O[7]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*Y[J]; O[8]:=O[8]+(P[J]*K[J])*(P[J]*K[J]); end; B[8]:=SS/O[8]; SS:=0; O[9]:=0;
160
for J:=1 to X do begin SS:=SS+K[J]*Q[J]*Y[J]; O[9]:=O[9]+(K[J]*Q[J])*(K[J]*Q[J]); end; B[9]:=SS/O[9]; end;{GB1480} procedure GB2040; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[12]:=O[12]+(P[J]*U[J])*(P[J]*U[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[13]:=O[13]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[14]:=O[14]+V[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[15]:=O[15]+(I[J]*V[J])*(I[J]*V[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[16]:=O[16]+(P[J]*V[J])*(P[J]*V[J]); end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Y[J]; O[17]:=O[17]+(U[J]*K[J])*(U[J]*K[J]); end;
161
B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[18]:=O[18]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[19]:=O[19]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[20]:=O[20]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*K[J]*Y[J]; O[21]:=O[21]+(P[J]*U[J]*K[J])*(P[J]*U[J]*K[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J]; O[22]:=O[22]+(K[J]*V[J])*(K[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[23]:=O[23]+(Q[J]*V[J])*(Q[J]*V[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*V[J]*Y[J]; O[25]:=O[25]+(P[J]*K[J]*V[J])*(P[J]*K[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Q[J]*Y[J]; O[26]:=O[26]+(U[J]*K[J]*Q[J])*(U[J]*K[J]*Q[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin
162
SS:=SS+K[J]*Q[J]*V[J]*Y[J]; O[27]:=O[27]+(K[J]*Q[J]*V[J])*(K[J]*Q[J]*V[J]); end; B[27]:=SS/O[27]; end;{GB2040} procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); var L2,N0,R0,N3,N4,N5:real; begin N0:=(ste(A,N)+ste(B,N)+ste(E,N))/3; R0:=(ste(A,R)+ste(B,R)+ste(E,R))/3; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(E,L2))/3; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(E,N4))/3; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); end;{GB3660} procedure GB4150; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; end; end;{GB4150} procedure GB4170; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; end; end;{GB4170} procedure GB4190; begin for J:=1 to X do begin U[J]:=ste(L[J],J3)+V3; V[J]:=ste(L[J],O3)+U3*ste(L[J],J3)+Q3; end; end;{GB4190} procedure GB4450; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]; N5:=B[8]*P[J]*K[J]+B[9]*K[J]*Q[J]; Z[J]:=N3+N4+N5; end; end;{GB4450} procedure GB4390; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]; end;{GB4390}
163
procedure GB4770; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]+B[12]*P[J]*U[J]; N6:=B[13]*I[J]*P[J]*U[J]+B[14]*V[J]+B[15]*I[J]*V[J]; N7:=B[16]*P[J]*V[J]+B[17]*U[J]*K[J]+B[18]*U[J]*Q[J]; R0:=B[19]*I[J]*P[J]*V[J]+B[20]*I[J]*U[J]*Q[J]; R4:=B[21]*P[J]*U[J]*K[J]+B[22]*K[J]*V[J]+B[23]*Q[J]*V[J]; R5:=B[24]*I[J]*Q[J]*V[J]+B[25]*P[J]*K[J]*V[J]; R6:=B[26]*U[J]*K[J]*Q[J]+B[27]*K[J]*Q[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6; end; end;{GB4770} end. unit TPG3_3; Interface uses tpg3_2; var grMode: Integer; procedure PR_MOD; procedure GB4880; procedure GB7000; procedure VVOD31; procedure VVOD32; procedure VVOD33; procedure tablF9; procedure OUT_F_H_L(PR:integer); Implementation procedure VVOD31; begin writeln('Ввод A1 E1 B1 J1 O1'); readln(A1,E1,B1,J1,O1); writeln(F0,'A1=',A1,' E1=',E1,' B1=',B1); writeln(F0,'J1=',J1,' O1=',O1); end;{VVOD31} procedure VVOD32; begin writeln('Ввод A2 E2 B2 J2 O2'); readln(A2,E2,B2,J2,O2); writeln(F0,'A2=',A2,' E2=',E2,' B2=',B2); writeln(F0,'J2=',J2,' O2=',O2); end;{VVOD32} procedure VVOD33; begin writeln('Ввод A3 E3 B3 J3 O3'); readln(A3,E3,B3,J3,O3); writeln(F0,'A3=',A3,' E3=',E3,' B3=',B3); writeln(F0,'J3=',J3,' O3=',O3); end;{VVOD33} procedure PR_MOD; begin case X of 3: begin F[1]:=A1; F[2]:=B1; F[3]:=E1; end; 9: begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1;
164
H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; end; 27:begin F[1]:=A1; H[1]:=A2; L[1]:=A3; F[2]:=B1; H[2]:=A2; L[2]:=A3; F[3]:=A1; H[3]:=B2; L[3]:=A3; F[4]:=B1; H[4]:=B2; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; F[9]:=A1; H[9]:=E2; L[9]:=E3; F[10]:=B1; H[10]:=E2; L[10]:=E3; F[11]:=E1; H[11]:=A2; L[11]:=E3; F[12]:=E1; H[12]:=B2; L[12]:=E3; F[13]:=E1; H[13]:=E2; L[13]:=A3; F[14]:=E1; H[14]:=E2; L[14]:=B3; F[15]:=A1; H[15]:=A2; L[15]:=E3; F[16]:=B1; H[16]:=A2; L[16]:=E3; F[17]:=A1; H[17]:=B2; L[17]:=E3; F[18]:=B1; H[18]:=B2; L[18]:=E3; F[19]:=A1; H[19]:=E2; L[19]:=A3; F[20]:=B1; H[20]:=E2; L[20]:=A3; F[21]:=A1; H[21]:=E2; L[21]:=B3; F[22]:=B1; H[22]:=E2; L[22]:=B3; F[23]:=E1; H[23]:=A2; L[23]:=A3; F[24]:=E1; H[24]:=B2; L[24]:=A3; F[25]:=E1; H[25]:=A2; L[25]:=B3; F[26]:=E1; H[26]:=B2; L[26]:=B3; F[27]:=E1; H[27]:=E2; L[27]:=E3; end; end; end; procedure GB4880; begin writeln(F0,'Математическая модель'); if X=3 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J),'); end; if X=9 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J),'); end; if X=27 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*P(J)*U(J)+',B[13]:10,'*I(J)*P(J)*U(J)+'); writeln(F0,'+',B[14]:10,'*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*P(J)*V(J)+',B[17]:10,'*U(J)*K(J)+'); writeln(F0,'+',B[18]:10,'*U(J)*Q(J)+',B[19]:10,'*I(J)*P(J)*V(J)+'); writeln(F0,'+',B[20]:10,'*I(J)*U(J)*Q(J)+',B[21]:10,'*P(J)*U(J)*K(J)+'); writeln(F0,'+',B[22]:10,'*K(J)*V(J)+',B[23]:10,'*Q(J)*V(J)+'); writeln(F0,'+',B[24]:10,'*I(J)*Q(J)*V(J)+',B[25]:10,'*P(J)*K(J)*V(J)+'); writeln(F0,'+',B[26]:10,'*U(J)*K(J)*Q(J)+',B[27]:10,'*K(J)*Q(J)*V(J),'); end;
165
if (X=3) or (X=9) or (X=27) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=9) or (X=27) then begin writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,','); writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10); end; if X=27 then begin writeln(F0,'U(J)=L(J)^',J3:10,'+',V3:10,','); write(F0,'V(J)=L(J)^',O3:10,'+',O3:10,'+',U3:10,'*L(J)^'); writeln(F0,J3:10,'+',Q3:10); end; end;{GB4880} procedure GB7000; label 1; begin repeat writeln('vvod X'); readln(X); writeln('X=',X); writeln(F0,'X=',X); if (X=3) then I0:=61; if (X=9) then I0:=62; if (X=27) then I0:=63; if I0=61 then begin case X of 3: I0:=73; end; F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end;{for} case I0 of 73:begin GB4150; GB4390; end; end;{case}
166
for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(73); end;{if} if I0=62 then begin case X of 9: I0:=76; end; F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); case I0 of 76:begin GB4150; GB4170; GB4450; end; end;{case} writeln('Z(',K5,')=',Z[K5]); end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(74); end;{if} if I0=63 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; X:=0;
167
writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X,F3,F4,H3,H4,L3,L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); GB4150; GB4170; GB4190; GB4770; end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(75); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); writeln(F0,'Выявление MAX Z(K5) и MIN Z(K5)'); K8:=0; K8:=Z[1]; for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; begin writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); end; for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin
168
KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln('Graphic. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000} procedure tablF9; begin write(' Значения F7 для 5% уровня'); writeln('значимости'); write('┌───┬──────────────────────────────────'); writeln('───────────────────────┐'); write('│ │ F9 '); writeln(' │'); write('│F8 ├────┬─────┬─────┬─────┬────┬─────┬'); writeln('─────┬─────┬─────┬─────┤'); write('│ │ 2 │ 3 │ 4 │ 8 │ 11 │ 14 │'); writeln('15-16│19-20│ 24 │26-30│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 2 │19.0│19.16│19.25│19.37│19.4│19.42│'); writeln('19.43│19.44│19.45│19.46│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 3 │9.55│ 9.28│ 9.12│ 8.84│8.76│ 8.71│'); writeln(' 8.69│ 8.66│ 8.64│ 8.62│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 4 │6.94│ 6.59│ 6.39│ 6.04│5.93│ 5.87│'); writeln(' 5.84│ 5.8 │ 5.77│ 5.74│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 5 │5.79│ 5.41│ 5.19│ 4.82│ 4.7│ 4.64│'); writeln(' 4.6 │ 4.56│ 4.53│ 4.5 │'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 6 │5.14│ 4.76│ 4.53│ 4.15│4.03│ 3.96│'); writeln(' 3.92│ 3.87│ 3.84│ 3.81│'); write('└───┴────┴─────┴─────┴─────┴────┴─────┴'); writeln('─────┴─────┴─────┴─────┘'); end;
169
procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────────'); writeln(F0,'─────────────────┐'); write(F0,'│ │ Значение'); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬────'); writeln(F0,'──────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ '); writeln(F0,'L(J) │ Z(J) │'); end; if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10); writeln(F0,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴');
170
writeln(F0,'──────────┴──────────┘'); end; end; end.
171
Программа NW0(три модуля tpg3, 2-я часть, _Х=3_, _Х=9_, _Х=27_, Х=4, Х=5, Х=12, Х=15, Х=16, Х=20, Х=25, «система» после «адекватно», 19.1-27.3)… program tpg3_1; {Математическое моделирование} uses tpg3_3, tpg3_2; label 1,2,3,4,5; procedure VV_DAN; begin case X of 4: begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); end; 16:begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); VVOD42; GB3710(A2,B2,C2,D2,J2,O2,P2,V2,U2,Q2,I2,M2,F2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); end; 20:begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2);
172
writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 5: begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); end; 25:begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 15:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1);
173
writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 3: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); end; 12:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD42; GB3710(A2,C2,D2,B2,J2,O2,P2,V2,U2,Q2,I2,M2,F2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); end; 9: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); end; 27:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации');
174
writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); VVOD33; GB3660(A3,E3,B3,J3,O3,V3,U3,Q3); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V3=',V3,' U3=',U3,' Q3=',Q3); writeln(F0,'V3=',V3,' U3=',U3,' Q3=',Q3); end; end;{case} end;{VV_DAN} procedure OUT_Z_B; begin writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln(F0,(Y[J]-Z[J]):10,'│'); write('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln((Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {================================================================ Основная программа =================================================================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из трех'); writeln('файлов tpg3_1,tpg3_2,tpg3_3(nw0_1,nw0_2,nw0_3). Математическое'); writeln(' моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программы GGN3.'); writeln(' Разработка Черного А.А.'); writeln(' Autor Chernyy Anatoly Alekseevech'); writeln('Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,'Выполнение программы математического моделирования'); writeln(F0,' tpg3_1 (nw0_1). (Программа на языке Турбо-Паскаль).'); writeln(F0,' Autor Chernyy Anatoly Alekseevech'); writeln('_X=3_,X=9_,_X=27_'); writeln('_X=3_, X=4,X=5, _X=9_ ,X=12,X=15,X=16,X=20,X=25,_X=27_'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0;
175
L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; VV_DAN; if X=0 then goto 2; PR_MOD; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение и'); writeln('ввод величин показателей Y(J)'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y(J)'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 3: GB4150; 4: GB4210; 5: GB4290; 9: begin GB4150; GB4170; end; 12:begin GB4150; GB4250; end; 15:begin GB4150; GB4340; end; 16:begin GB4210; GB4250; end; 20:begin GB4210; GB4340; end; 25:begin GB4290; GB4340; end; 27:begin GB4150; GB4170; GB4190; end; end;{case} GB1410; case X of
176
4: GB2000; 5: begin GB2000; GB2020; end; 9: begin GB1480; end; 12:begin GB1480; GB1600; end; 15:begin GB1480; GB1600; GB1670; end; 16:begin GB1480; GB1600; GB1930; end; 20:begin GB1480; GB1600; GB1670; GB1730; end; 25:begin GB1480; GB1600; GB1670; GB1730; GB1830; end; 27:begin GB1480; GB2040; end; end; writeln('B(J) до анализа'); writeln(F0,'B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 3: GB4390; 4: GB4400; 5: GB4420; 9: GB4450; 12:GB4490; 15:GB4530; 16:GB4580; 20:GB4630; 25:GB4690; 27:GB4770; else goto 2; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=30 then goto 3; if I0=25 then begin GB4880; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'Количество опытов на среднем уровне факторов N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8);
177
end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if not(I0=5) then begin writeln('Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'Табличный T-критерий T0=',T0:5:3); writeln('B(J) после анализа'); writeln(F0,'B(J) после анализа'); for J:=1 to X do begin if T[J]
178
K9:=0; for J:=1 to X do begin if B[J]=0 then K9:=K9+1; end; writeln('Количество статистически значимых'); writeln('коэффициентов регрессии'); writeln('K9=',K9); writeln('F9=X-1'); F9:=X-1; writeln('F9=',F9); writeln(F0,'Количество статистически значимых'); writeln(F0,'коэффициентов регрессии'); writeln(F0,'K9=',K9); writeln(F0,'F9=X-1'); F9:=X-1; writeln(F0,'F9=',F9); tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 3: GB4390; 4: GB4400; 5: GB4420; 9: GB4450; 12:GB4490; 15:GB4530; 16:GB4580; 20:GB4630; 25:GB4690; 27:GB4770; else goto 2; end; writeln('Расчетные величины показателя'); writeln('Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then begin
179
writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; if X=3 then begin writeln(F0,'X=3. System, 1.1 - 1.3, finish 1.3.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','E1=',E1,'Z(3)=',Z[3]); writeln(F0,'1.3.','B1=',B1,'Z(2)=',Z[2]); end; if X=9 then begin writeln(F0,'X=9. System, 1.1 - 6.3, finish 6.3.'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'E1=',E1,'Z(7)=',Z[7]); writeln(F0,'1.3.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','E2=',E2,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'2.2.','E2=',E2,'E1=',E1,'Z(9)=',Z[9]); writeln(F0,'2.3.','E2=',E2,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'3.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'3.2.','B2=',B2,'E1=',E1,'Z(8)=',Z[8]); writeln(F0,'3.3.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'4.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'4.2.','A1=',A1,'E2=',E2,'Z(5)=',Z[5]); writeln(F0,'4.3.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'5.1.','E1=',E1,'A2=',A2,'Z(7)=',Z[7]); writeln(F0,'5.2.','E1=',E1,'E2=',E2,'Z(9)=',Z[9]); writeln(F0,'5.3.','E1=',E1,'B2=',B2,'Z(8)=',Z[8]); writeln(F0,'6.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'6.2.','B1=',B1,'E2=',E2,'Z(6)=',Z[6]); writeln(F0,'6.3.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); end; if X=27 then begin writeln(F0,'X=27. System, 19.1 - 27.2, finish 27.2.'); writeln(F0,'19.1.','A1=',A1,'A2=',A2,'A3=',A3,'Z(1)=',Z[1]); writeln(F0,'19.2.','A1=',A1,'A2=',A2,'E3=',E3,'Z(15)=',Z[15]); writeln(F0,'19.3.','A1=',A1,'A2=',A2,'B3=',B3,'Z(5)=',Z[5]); writeln(F0,'20.1.','A1=',A1,'E2=',E2,'A3=',A3,'Z(19)=',Z[19]); writeln(F0,'20.2.','A1=',A1,'E2=',E2,'E3=',E3,'Z(9)=',Z[9]); writeln(F0,'20.3.','A1=',A1,'E2=',E2,'B3=',B3,'Z(21)=',Z[21]); writeln(F0,'21.1.','A1=',A1,'B2=',B2,'A3=',A3,'Z(3)=',Z[3]); writeln(F0,'21.2.','A1=',A1,'B2=',B2,'E3=',E3,'Z(17)=',Z[17]); writeln(F0,'21.3.','A1=',A1,'B2=',B2,'B3=',B3,'Z(7)=',Z[7]); writeln(F0,'22.1.','E1=',E1,'A2=',A2,'A3=',A3,'Z(23)=',Z[23]); writeln(F0,'22.2.','E1=',E1,'A2=',A2,'E3=',E3,'Z(11)=',Z[11]); writeln(F0,'22.3.','E1=',E1,'A2=',A2,'B3=',B3,'Z(25)=',Z[25]); writeln(F0,'23.1.','E1=',E1,'E2=',E2,'A3=',A3,'Z(13)=',Z[13]); writeln(F0,'23.2.','E1=',E1,'E2=',E2,'E3=',E3,'Z(27)=',Z[27]); writeln(F0,'23.3.','E1=',E1,'E2=',E2,'B3=',B3,'Z(14)=',Z[14]); writeln(F0,'24.1.','E1=',E1,'B2=',B2,'A3=',A3,'Z(24)=',Z[24]); writeln(F0,'24.2.','E1=',E1,'B2=',B2,'E3=',E3,'Z(12)=',Z[12]); writeln(F0,'24.3.','E1=',E1,'B2=',B2,'B3=',B3,'Z(26)=',Z[26]); writeln(F0,'25.1.','B1=',B1,'A2=',A2,'A3=',A3,'Z(2)=',Z[2]); writeln(F0,'25.2.','B1=',B1,'A2=',A2,'E3=',E3,'Z(16)=',Z[16]); writeln(F0,'25.3.','B1=',B1,'A2=',A2,'B3=',B3,'Z(6)=',Z[6]); writeln(F0,'26.1.','B1=',B1,'E2=',E2,'A3=',A3,'Z(20)=',Z[20]);
180
writeln(F0,'26.2.','B1=',B1,'E2=',E2,'E3=',E3,'Z(10)=',Z[10]); writeln(F0,'26.3.','B1=',B1,'E2=',E2,'B3=',B3,'Z(22)=',Z[22]); writeln(F0,'27.1.','B1=',B1,'B2=',B2,'A3=',A3,'Z(4)=',Z[4]); writeln(F0,'27.2.','B1=',B1,'B2=',B2,'E3=',E3,'Z(18)=',Z[18]); writeln(F0,'27.3.','B1=',B1,'B2=',B2,'B3=',B3,'Z(8)=',Z[8]); end; case X of 3: OUT_F_H_L(73); 4: OUT_F_H_L(73); 5: OUT_F_H_L(73); 9: OUT_F_H_L(74); 12:OUT_F_H_L(74); 15:OUT_F_H_L(74); 16:OUT_F_H_L(74); 20:OUT_F_H_L(74); 25:OUT_F_H_L(74); 27:OUT_F_H_L(75); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB4880; goto 2; end; if I0=22 then begin GB7000; goto 2; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S) - 1,2,3 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S) - 1,2,3 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'расчеты по модели'); if (X=3)or(X=4)or(X=5)then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); case X of 3: begin GB4150; GB4390; end;
181
4: begin GB4210; GB4400; end; 5: begin GB4290; GB4420; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(73); end;{if} if (X=9)or(X=12)or(X=15)or(X=16)or(X=20)or(X=25)then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; H[S]:=0; writeln('Ввод F(',S,')',' H(',S,')'); readln(F[S],H[S]); case X of 9: begin GB4150; GB4170; GB4450; end; 12:begin GB4150; GB4250; GB4490; end; 15:begin GB4150; GB4340; GB4530; end; 16:begin GB4210; GB4250; GB4580; end; 20:begin GB4210; GB4340; GB4630; end; 25:begin GB4290; GB4340; GB4690; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(74); end;{if} if X=27 then begin for S:=1 to X do begin writeln('Ввод F(',S,')',' H(',S,')',' L(',S,')'); readln(F[S],H[S],L[S]); GB4150; GB4170; GB4190; GB4770; writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(75); end;{if} 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности');
182
writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if I0=11 then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end.{Конец программы} unit TPG3_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2:real; T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0: Text; procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); procedure GB3710(A,B,C,D,N,R,S:real; var V0,U0,Q0,I0,M0,F0:real); procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); function ste(Q,A:real):real; procedure GB1410; procedure GB1480; procedure GB1600; procedure GB1670; procedure GB1730; procedure GB1830; procedure GB1930; procedure GB2000; procedure GB2020; procedure GB2040; procedure GB4150; procedure GB4210; procedure GB4290; procedure GB4170; procedure GB4190; procedure GB4250; procedure GB4340; procedure GB4400; procedure GB4420; procedure GB4450; procedure GB4490; procedure GB4530; procedure GB4580; procedure GB4630; procedure GB4690; procedure GB4390; procedure GB4770; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then begin
183
A:=abs(A); if Q=0 then Q:=1E-5; ste:=1/exp(A*ln(Q)); end else begin if Q=0 then Q:=1E-5; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure GB1410; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+K[J]*Y[J]; O[3]:=O[3]+K[J]*K[J]; end; B[3]:=SS/O[3]; end;{GB1410} procedure GB1480; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[4]:=O[4]+P[J]*P[J]; end; B[4]:=SS/O[4]; SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[5]:=O[5]+(I[J]*P[J])*(I[J]*P[J]); end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[6]:=O[6]+Q[J]*Q[J]; end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[7]:=O[7]+(I[J]*Q[J])*(I[J]*Q[J]);
184
end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*Y[J]; O[8]:=O[8]+(P[J]*K[J])*(P[J]*K[J]); end; B[8]:=SS/O[8]; SS:=0; O[9]:=0; for J:=1 to X do begin SS:=SS+K[J]*Q[J]*Y[J]; O[9]:=O[9]+(K[J]*Q[J])*(K[J]*Q[J]); end; B[9]:=SS/O[9]; end;{GB1480} procedure GB1600; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+K[J]*U[J]*Y[J]; O[12]:=O[12]+K[J]*U[J]*K[J]*U[J]; end; B[12]:=SS/O[12]; end;{GB1600} procedure GB1670; begin SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[13]:=O[13]+V[J]*V[J]; end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[14]:=O[14]+I[J]*V[J]*I[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J]; O[15]:=O[15]+K[J]*V[J]*K[J]*V[J]; end;
185
B[15]:=SS/O[15]; end;{GB1670} procedure GB1730; begin SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[16]:=O[16]+L[J]*L[J]; end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+P[J]*L[J]*Y[J]; O[17]:=O[17]+(P[J]*L[J])*(P[J]*L[J]); end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+Q[J]*L[J]*Y[J]; O[18]:=O[18]+(Q[J]*L[J])*(Q[J]*L[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+L[J]*U[J]*Y[J]; O[19]:=O[19]+(L[J]*U[J])*(L[J]*U[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+L[J]*V[J]*Y[J]; O[20]:=O[20]+(L[J]*V[J])*(L[J]*V[J]); end; B[20]:=SS/O[20]; end;{GB1730} procedure GB1830; begin SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+M[J]*Y[J]; O[21]:=O[21]+M[J]*M[J]; end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+P[J]*M[J]*Y[J]; O[22]:=O[22]+(P[J]*M[J])*(P[J]*M[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*M[J]*Y[J]; O[23]:=O[23]+(Q[J]*M[J])*(Q[J]*M[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0;
186
for J:=1 to X do begin SS:=SS+U[J]*M[J]*Y[J]; O[24]:=O[24]+(U[J]*M[J])*(U[J]*M[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+M[J]*V[J]*Y[J]; O[25]:=O[25]+(M[J]*V[J])*(M[J]*V[J]); end; B[25]:=SS/O[25]; end;{GB1830} procedure GB1930; begin SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[13]:=O[13]+L[J]*L[J]; end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+P[J]*L[J]*Y[J]; O[14]:=O[14]+(P[J]*L[J])*(P[J]*L[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+Q[J]*L[J]*Y[J]; O[15]:=O[15]+(Q[J]*L[J])*(Q[J]*L[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+L[J]*U[J]*Y[J]; O[16]:=O[16]+(L[J]*U[J])*(L[J]*U[J]); end; B[16]:=SS/O[16]; end;{GB1930} procedure GB2000; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[4]:=O[4]+L[J]*L[J]; end; B[4]:=SS/O[4]; end;{GB2000} procedure GB2020; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+M[J]*Y[J];
187
O[5]:=O[5]+M[J]*M[J]; end; B[5]:=SS/O[5]; end;{GB2020} procedure GB2040; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[12]:=O[12]+(P[J]*U[J])*(P[J]*U[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[13]:=O[13]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[14]:=O[14]+V[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[15]:=O[15]+(I[J]*V[J])*(I[J]*V[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[16]:=O[16]+(P[J]*V[J])*(P[J]*V[J]); end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Y[J]; O[17]:=O[17]+(U[J]*K[J])*(U[J]*K[J]); end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin
188
SS:=SS+U[J]*Q[J]*Y[J]; O[18]:=O[18]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[19]:=O[19]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[20]:=O[20]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*K[J]*Y[J]; O[21]:=O[21]+(P[J]*U[J]*K[J])*(P[J]*U[J]*K[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J]; O[22]:=O[22]+(K[J]*V[J])*(K[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[23]:=O[23]+(Q[J]*V[J])*(Q[J]*V[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*V[J]*Y[J]; O[25]:=O[25]+(P[J]*K[J]*V[J])*(P[J]*K[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Q[J]*Y[J]; O[26]:=O[26]+(U[J]*K[J]*Q[J])*(U[J]*K[J]*Q[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin SS:=SS+K[J]*Q[J]*V[J]*Y[J]; O[27]:=O[27]+(K[J]*Q[J]*V[J])*(K[J]*Q[J]*V[J]); end;
189
B[27]:=SS/O[27]; end;{GB2040} procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); var L2,N0,R0,N3,N4,N5:real; begin N0:=(ste(A,N)+ste(B,N)+ste(E,N))/3; R0:=(ste(A,R)+ste(B,R)+ste(E,R))/3; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(E,L2))/3; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(E,N4))/3; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); end;{GB3660} procedure GB3710(A,B,C,D,N,R,S:real; var V0,U0,Q0,I0,M0,F0:real); var N0,R0,S0,L2,N3,K2,R3,N4,N5,N6,N7,R4,R5,P0,Z1,Z2,Z3:real; begin N0:=(ste(A,N)+ste(B,N)+ste(C,N)+ste(D,N))/4; R0:=(ste(A,R)+ste(B,R)+ste(C,R)+ste(D,R))/4; S0:=(ste(A,S)+ste(B,S)+ste(C,S)+ste(D,S))/4; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(C,L2)+ste(D,L2))/4; K2:=2*R; R3:=(ste(A,K2)+ste(B,K2)+ste(C,K2)+ste(D,K2))/4; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(C,N4)+ste(D,N4))/4; N6:=N+S; N7:=(ste(A,N6)+ste(B,N6)+ste(C,N6)+ste(D,N6))/4; R4:=R+S; R5:=(ste(A,R4)+ste(B,R4)+ste(C,R4)+ste(D,R4))/4; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); P0:=(N0*S0-N7)/(N3-N0*N0); Z1:=R0*S0-R5+P0*(N0*R0-N5); Z2:=U0*(N0*S0-N7)+U0*P0*(N0*N0-N3); Z3:=R3-R0*R0+2*U0*(N5-N0*R0); I0:=(Z1+Z2)/(Z3+(N3-N0*N0)*U0*U0); M0:=I0*U0+P0; F0:=-(S0+I0*R0+M0*N0); end;{GB3710} procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); var N0,R0,S0,W0,L2,N3,K2,R3,M2,S3,N4,N5:real; N6,N7,N8,N9,R4,R5,R6,R7,S4,S5,P0:real; Z1,Z2,Z3,Z4,Z5,Z6,Z7,Z0,Z8,Z9,T7:real; T8,T9,G3,G4,G5,G6,G7:real; begin N0:=(ste(A,N)+ste(B,N)+ste(C,N)+ste(D,N)+ste(E,N))/5; R0:=(ste(A,R)+ste(B,R)+ste(C,R)+ste(D,R)+ste(E,R))/5; S0:=(ste(A,S)+ste(B,S)+ste(C,S)+ste(D,S)+ste(E,S))/5; W0:=(ste(A,W)+ste(B,W)+ste(C,W)+ste(D,W)+ste(E,W))/5; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(C,L2)+ste(D,L2)+ste(E,L2))/5;
190
K2:=2*R; R3:=(ste(A,K2)+ste(B,K2)+ste(C,K2)+ste(D,K2)+ste(E,K2))/5; M2:=2*S; S3:=(ste(A,M2)+ste(B,M2)+ste(C,M2)+ste(D,M2)+ste(E,M2))/5; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(C,N4)+ste(D,N4)+ste(E,N4))/5; N6:=N+S; N7:=(ste(A,N6)+ste(B,N6)+ste(C,N6)+ste(D,N6)+ste(E,N6))/5; N8:=N+W; N9:=(ste(A,N8)+ste(B,N8)+ste(C,N8)+ste(D,N8)+ste(E,N8))/5; R4:=R+S; R5:=(ste(A,R4)+ste(B,R4)+ste(C,R4)+ste(D,R4)+ste(E,R4))/5; R6:=R+W; R7:=(ste(A,R6)+ste(B,R6)+ste(C,R6)+ste(D,R6)+ste(E,R6))/5; S4:=S+W; S5:=(ste(A,S4)+ste(B,S4)+ste(C,S4)+ste(D,S4)+ste(E,S4))/5; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); P0:=(N0*S0-N7)/(N3-N0*N0); Z1:=R0*S0-R5+P0*(N0*R0-N5); Z2:=U0*(N0*S0-N7)+U0*P0*(N0*N0-N3); Z3:=R3-R0*R0+2*U0*(N5-N0*R0); I0:=(Z1+Z2)/(Z3+(N3-N0*N0)*U0*U0); M0:=I0*U0+P0; F0:=-(S0+I0*R0+M0*N0); Z4:=R0+U0*N0; Z5:=Z4*N0-N5-U0*N3; Z6:=R3+U0*N5-Z4*R0-Z5*U0; Z7:=Z4*S0+Z5*P0-R5-U0*N7; Z0:=(N0*W0-N9)/(N3-N0*N0); Z8:=Z5*Z0+Z4*W0-R7-U0*N9; Z9:=S3+I0*R5+M0*N7; T7:=R5+I0*R3+M0*N5; T8:=N7+I0*N5+M0*N3; T9:=S0+I0*R0+M0*N0; G3:=S5+I0*R7+M0*N9; G4:=T9*N0-T8; G5:=Z9-T9*S0-G4*P0; G6:=T9*R0-T7+G4*U0; G7:=G4*Z0+T9*W0-G3; G0:=(Z6*G7+Z8*G6)/(Z6*G5-Z7*G6); H0:=(G0*Z7+Z8)/Z6; K0:=G0*P0+H0*U0+Z0; L0:=-(W0+G0*S0+H0*R0+K0*N0); end;{GB3860} procedure GB4150; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; end; end;{GB4150} procedure GB4210; begin for J:=1 to X do
191
begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; L[J]:=ste(F[J],P1)+I1*ste(F[J],O1)+M1*ste(F[J],J1)+F1; end; end;{Gb4210} procedure GB4290; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; L[J]:=ste(F[J],P1)+I1*ste(F[J],O1)+M1*ste(F[J],J1)+F1; M[J]:=ste(F[J],T1)+G1*ste(F[J],P1)+H1*ste(F[J],O1) +K1*ste(F[J],J1)+L1; end; end;{GB4290} procedure GB4170; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; end; end;{GB4170} procedure GB4190; begin for J:=1 to X do begin U[J]:=ste(L[J],J3)+V3; V[J]:=ste(L[J],O3)+U3*ste(L[J],J3)+Q3; end; end;{GB4190} procedure GB4250; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; U[J]:=ste(H[J],P2)+I2*ste(H[J],O2)+M2*ste(H[J],J2)+F2; end; end;{GB4250} procedure GB4340; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; U[J]:=ste(H[J],P2)+I2*ste(H[J],O2)+M2*ste(H[J],J2)+F2; V[J]:=ste(H[J],T2)+G2*ste(H[J],P2)+H2*ste(H[J],O2) +K2*ste(H[J],J2)+L2; end; end;{GB4340} procedure GB4400; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*L[J];
192
end;{GB4400} procedure GB4420; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*L[J]+B[5]*M[J]; end;{GB4420} procedure GB4450; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]; N5:=B[8]*P[J]*K[J]+B[9]*K[J]*Q[J]; Z[J]:=N3+N4+N5; end; end;{GB4450} procedure GB4490; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; Z[J]:=N3+N4+N5+B[12]*K[J]*U[J]; end; end;{GB4490} procedure GB4530; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]; Z[J]:=N3+N4+N5+N6+B[15]*K[J]*V[J]; end; end;{GB4530} procedure GB4580; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]+B[12]*K[J]*U[J]; N6:=B[13]*L[J]+B[14]*P[J]*L[J]+B[15]*Q[J]*L[J]; Z[J]:=N3+N4+N5+N6+B[16]*L[J]*U[J]; end; end;{GB4580} procedure GB4630; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]+B[15]*K[J]*V[J]; N7:=B[16]*L[J]+B[17]*P[J]*L[J]+B[18]*Q[J]*L[J]+B[19]*L[J]*U[J];
193
Z[J]:=N3+N4+N5+N6+N7+B[20]*L[J]*V[J]; end; end;{GB4630} procedure GB4690; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]+B[15]*K[J]*V[J]; N7:=B[16]*L[J]+B[17]*P[J]*L[J]+B[18]*Q[J]*L[J]+B[19]*L[J]*U[J]; R3:=B[20]*L[J]*V[J]+B[21]*M[J]+B[22]*P[J]*M[J]; R4:=B[23]*Q[J]*M[J]+B[24]*U[J]*M[J]+B[25]*M[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R3+R4; end; end;{GB4690} procedure GB4390; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]; end;{GB4390} procedure GB4770; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]+B[12]*P[J]*U[J]; N6:=B[13]*I[J]*P[J]*U[J]+B[14]*V[J]+B[15]*I[J]*V[J]; N7:=B[16]*P[J]*V[J]+B[17]*U[J]*K[J]+B[18]*U[J]*Q[J]; R0:=B[19]*I[J]*P[J]*V[J]+B[20]*I[J]*U[J]*Q[J]; R4:=B[21]*P[J]*U[J]*K[J]+B[22]*K[J]*V[J]+B[23]*Q[J]*V[J]; R5:=B[24]*I[J]*Q[J]*V[J]+B[25]*P[J]*K[J]*V[J]; R6:=B[26]*U[J]*K[J]*Q[J]+B[27]*K[J]*Q[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6; end; end;{GB4770} end. unit TPG3_3; Interface uses tpg3_2; var grDriver: Integer; grMode: Integer; procedure PR_MOD; procedure GB4880; procedure GB7000; procedure VVOD31; procedure VVOD32; procedure VVOD33; procedure VVOD41; procedure VVOD42; procedure VVOD51; procedure VVOD52; procedure tablF9; procedure OUT_F_H_L(PR:integer); Implementation procedure VVOD31; begin writeln('Ввод A1 E1 B1 J1 O1'); readln(A1,E1,B1,J1,O1);
194
writeln(F0,'A1=',A1,' E1=',E1,' B1=',B1); writeln(F0,'J1=',J1,' O1=',O1); end;{VVOD31} procedure VVOD32; begin writeln('Ввод A2 E2 B2 J2 O2'); readln(A2,E2,B2,J2,O2); writeln(F0,'A2=',A2,' E2=',E2,' B2=',B2); writeln(F0,'J2=',J2,' O2=',O2); end;{VVOD32} procedure VVOD33; begin writeln('Ввод A3 E3 B3 J3 O3'); readln(A3,E3,B3,J3,O3); writeln(F0,'A3=',A3,' E3=',E3,' B3=',B3); writeln(F0,'J3=',J3,' O3=',O3); end;{VVOD33} procedure VVOD41; begin writeln('Ввод A1 C1 D1 B1 J1 O1 P1'); readln(A1,C1,D1,B1,J1,O1,P1); writeln(F0,'A1=',A1,' C1=',C1,' D1=',D1); writeln(F0,'B1=',B1,' J1=',J1,' O1=',O1); writeln(F0,'P1=',P1); end;{VVOD41} procedure VVOD42; begin writeln('Ввод A2 C2 D2 B2 J2 O2 P2'); readln(A2,C2,D2,B2,J2,O2,P2); writeln(F0,'A2=',A2,' C2=',C2,' D2=',D2); writeln(F0,'B2=',B2,' J2=',J2,' O2=',O2); writeln(F0,'P2=',P2); end;{VVOD42} procedure VVOD51; begin writeln('Ввод A1 C1 E1 D1 B1 J1 O1 P1 T1'); readln(A1,C1,E1,D1,B1,J1,O1,P1,T1); writeln(F0,'A1=',A1,' C1=',C1,' E1=',E1); writeln(F0,'D1=',D1,' B1=',B1,' J1=',J1); writeln(F0,'O1=',O1,' P1=',P1,' T1=',T1); end;{VVOD51} procedure VVOD52; begin writeln('Ввод A2 C2 E2 D2 B2 J2 O2 P2 T2'); readln(A2,C2,E2,D2,B2,J2,O2,P2,T2); writeln(F0,'A2=',A2,' C2=',C2,' E2=',E2); writeln(F0,'D2=',D2,' B2=',B2,' J2=',J2); writeln(F0,'O2=',O2,' P2=',P2,' T2=',T2); end;{VVOD52} procedure PR_MOD; begin case X of 3: begin F[1]:=A1; F[2]:=B1; F[3]:=E1; end; 4: begin F[1]:=A1; F[2]:=B1; F[3]:=C1; F[4]:=D1;
195
end; 5: begin F[1]:=A1; F[2]:=B1; F[3]:=C1; F[4]:=D1; F[5]:=E1; end; 9: begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; end; 12:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=E1; H[5]:=A2; F[6]:=E1; H[6]:=B2; F[7]:=A1; H[7]:=C2; F[8]:=B1; H[8]:=D2; F[9]:=A1; H[9]:=D2; F[10]:=B1; H[10]:=C2; F[11]:=E1; H[11]:=C2; F[12]:=E1; H[12]:=D2; end; 15:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; F[10]:=A1; H[10]:=C2; F[11]:=B1; H[11]:=D2; F[12]:=A1; H[12]:=D2; F[13]:=B1; H[13]:=C2; F[14]:=E1; H[14]:=C2; F[15]:=E1; H[15]:=D2; end; 16:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=C2; F[6]:=B1; H[6]:=C2; F[7]:=A1; H[7]:=D2; F[8]:=B1; H[8]:=D2; F[9]:=C1; H[9]:=A2; F[10]:=C1; H[10]:=C2; F[11]:=C1; H[11]:=D2; F[12]:=C1; H[12]:=B2; F[13]:=D1; H[13]:=A2; F[14]:=D1; H[14]:=C2; F[15]:=D1; H[15]:=D2; F[16]:=D1; H[16]:=B2; end; 20:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=A1; H[7]:=C2; F[8]:=B1; H[8]:=D2; F[9]:=A1; H[9]:=D2; F[10]:=B1; H[10]:=C2; F[11]:=C1; H[11]:=A2; F[12]:=C1; H[12]:=C2; F[13]:=C1; H[13]:=E2; F[14]:=C1; H[14]:=D2; F[15]:=C1; H[15]:=B2; F[16]:=D1; H[16]:=A2; F[17]:=D1; H[17]:=C2; F[18]:=D1; H[18]:=E2; F[19]:=D1; H[19]:=D2; F[20]:=D1; H[20]:=B2; end; 25:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; F[10]:=A1; H[10]:=C2; F[11]:=B1; H[11]:=D2; F[12]:=A1; H[12]:=D2; F[13]:=B1; H[13]:=C2; F[14]:=E1; H[14]:=C2; F[15]:=E1; H[15]:=D2; F[16]:=C1; H[16]:=A2; F[17]:=C1; H[17]:=C2; F[18]:=C1; H[18]:=E2; F[19]:=C1; H[19]:=D2; F[20]:=C1; H[20]:=B2; F[21]:=D1; H[21]:=A2; F[22]:=D1; H[22]:=C2; F[23]:=D1; H[23]:=E2; F[24]:=D1; H[24]:=D2; F[25]:=D1; H[25]:=B2; end; 27:begin
196
F[1]:=A1; H[1]:=A2; L[1]:=A3; F[2]:=B1; H[2]:=A2; L[2]:=A3; F[3]:=A1; H[3]:=B2; L[3]:=A3; F[4]:=B1; H[4]:=B2; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; F[9]:=A1; H[9]:=E2; L[9]:=E3; F[10]:=B1; H[10]:=E2; L[10]:=E3; F[11]:=E1; H[11]:=A2; L[11]:=E3; F[12]:=E1; H[12]:=B2; L[12]:=E3; F[13]:=E1; H[13]:=E2; L[13]:=A3; F[14]:=E1; H[14]:=E2; L[14]:=B3; F[15]:=A1; H[15]:=A2; L[15]:=E3; F[16]:=B1; H[16]:=A2; L[16]:=E3; F[17]:=A1; H[17]:=B2; L[17]:=E3; F[18]:=B1; H[18]:=B2; L[18]:=E3; F[19]:=A1; H[19]:=E2; L[19]:=A3; F[20]:=B1; H[20]:=E2; L[20]:=A3; F[21]:=A1; H[21]:=E2; L[21]:=B3; F[22]:=B1; H[22]:=E2; L[22]:=B3; F[23]:=E1; H[23]:=A2; L[23]:=A3; F[24]:=E1; H[24]:=B2; L[24]:=A3; F[25]:=E1; H[25]:=A2; L[25]:=B3; F[26]:=E1; H[26]:=B2; L[26]:=B3; F[27]:=E1; H[27]:=E2; L[27]:=E3; end; end; end; procedure GB4880; begin writeln(F0,'Математическая модель'); if X=3 then writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J),'); if X=9 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J),'); end; if X=27 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*P(J)*U(J)+',B[13]:10,'*I(J)*P(J)*U(J)+'); writeln(F0,'+',B[14]:10,'*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*P(J)*V(J)+',B[17]:10,'*U(J)*K(J)+'); writeln(F0,'+',B[18]:10,'*U(J)*Q(J)+',B[19]:10,'*I(J)*P(J)*V(J)+'); writeln(F0,'+',B[20]:10,'*I(J)*U(J)*Q(J)+',B[21]:10,'*P(J)*U(J)*K(J)+'); writeln(F0,'+',B[22]:10,'*K(J)*V(J)+',B[23]:10,'*Q(J)*V(J)+'); writeln(F0,'+',B[24]:10,'*I(J)*Q(J)*V(J)+',B[25]:10,'*P(J)*K(J)*V(J)+'); writeln(F0,'+',B[26]:10,'*U(J)*K(J)*Q(J)+',B[27]:10,'*K(J)*Q(J)*V(J),'); end; if (X=3) or (X=27) or (X=9) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=9) or (X=27) then begin writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,',');
197
writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10); end; if X=27 then begin writeln(F0,'U(J)=L(J)^',J3:10,'+',V3:10,','); write(F0,'V(J)=L(J)^',O3:10,'+',O3:10,'+',U3:10,'*L(J)^'); writeln(F0,J3:10,'+',Q3:10); end; if X=4 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*L(J),'); end; if X=5 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*L(J)+',B[5]:10,'*M(J),'); end; if X=12 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J),'); end; if X=15 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*K(J)*V(J),'); end; if X=16 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*L(J)+'); writeln(F0,'+',B[14]:10,'*P(J)*L(J)+',B[15]:10,'*Q(J)*L(J)+'); writeln(F0,'+',B[16]:10,'*L(J)*U(J),'); end; if X=20 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)+Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*I(J)*V(J)+');
198
writeln(F0,'+',B[16]:10,'*L(J)+',B[17]:10,'*P(J)*L(J)+'); writeln(F0,'+',B[18]:10,'*Q(J)*L(J)+',B[19]:10,'*L(J)*U(J)+'); writeln(F0,'+',B[20]:10,'*L(J)*V(J),'); end; if X=25 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*Q(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*L(J)+',B[17]:10,'*P(J)*L(J)+'); writeln(F0,'+',B[18]:10,'*Q(J)*L(J)+',B[19]:10,'*L(J)*U(J)+'); writeln(F0,'+',B[20]:10,'*L(J)*V(J)+',B[21]:10,'*M(J)+'); writeln(F0,'+',B[22]:10,'*P(J)*M(J)+',B[23]:10,'*Q(J)*M(J)+'); writeln(F0,'+',B[24]:10,'*U(J)*M(J)+',B[25]:10,'*M(J)*V(J),'); end; if (X=4)or(X=5)or(X=12)or(X=15)or(X=16)or (X=20)or(X=20)or(X=25) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=4)or(X=5)or(X=16)or(X=20)or(X=25)then begin writeln(F0,'L(J)=F(J)^',P1:10,'+',I1:10,'*F(J)^',O1:10,'+'); writeln(F0,'+',M1:10,'F(J)^',J1:10,'+',F1:10); end; if (X=5)or(X=25) then begin writeln(F0,'M(J)=F(J)^',T1:10,'+',G1:10,'*F(J)^',P1:10,'+'); writeln(F0,'+',H1:10,'*F(J)^',O1:10,'+',K1:10,'*F(J)^',I1:10,'+',L1:10); end; if (X=12)or(X=15) or (X=16) or (X=20) or (X=25) then begin writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,','); writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10,','); writeln(F0,'U(J)=H(J)^',P2:10,'+',I2:10,'*H(J)^',O2:10,'+'); writeln(F0,'+',M2:10,'*H(J)^',J2:10,'+',F2:10); end; if (X=12) or (X=15) or (X=20) or (X=25) then begin writeln(F0,'V(J)=H(J)^',T2:10,'+',G2:10,'*H(J)^',P2:10,'+'); writeln(F0,'+',H2:10,'*H(J)^',O2:10,'+',K2:10,'*H(J)^',J2:10,'+'); writeln(F0,'+',L2:10); end; end;{GB4880} procedure GB7000; label 1; begin repeat writeln('vvod X'); readln(X); writeln('X=',X);
199
writeln(F0,'X=',X); if (X=3)or(X=4)or(X=5) then I0:=61; if (X=9)or(X=12)or(X=15)or(X=16)or(X=20)or(X=25) then I0:=62; if X=27 then I0:=63; if I0=61 then begin case X of 3: I0:=73; 4: I0:=74; 5: I0:=75; end; F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end;{for} case I0 of 73:begin GB4150; GB4390; end; 74:begin GB4210; GB4400; end; 75:begin GB4290; GB4420; end; end;{case} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(73); end;{if} if I0=62 then begin case X of 9: I0:=76; 12:I0:=77; 15:I0:=78; 16:I0:=79; 20:I0:=80; 25:I0:=81; end; F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4');
200
writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); case I0 of 76:begin GB4150; GB4170; GB4450; end; 77:begin GB4150; GB4250; GB4490; end; 78:begin GB4150; GB4340; GB4530; end; 79:begin GB4210; GB4250; GB4580; end; 80:begin GB4210; GB4340; GB4630; end; 81:begin GB4290; GB4340; GB4690; end; end;{case} writeln('Z(',K5,')=',Z[K5]); end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(74); end;{if} if I0=63 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do begin
201
F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; X:=0; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X,F3,F4,H3,H4,L3,L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); GB4150; GB4170; GB4190; GB4770; end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(75); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); writeln(F0,'Выявление MAX Z(K5) и MIN Z(K5)'); writeln('Ввод I0=90-продолжение'); K8:=0; K8:=Z[1]; readln(I0); for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8');
202
writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000} procedure tablF9; begin write(' Значения F7 для 5% уровня'); writeln('значимости'); write('┌───┬──────────────────────────────────'); writeln('───────────────────────┐'); write('│ │ F9 '); writeln(' │'); write('│F8 ├────┬─────┬─────┬─────┬────┬─────┬'); writeln('─────┬─────┬─────┬─────┤'); write('│ │ 2 │ 3 │ 4 │ 8 │ 11 │ 14 │'); writeln('15-16│19-20│ 24 │26-30│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 2 │19.0│19.16│19.25│19.37│19.4│19.42│'); writeln('19.43│19.44│19.45│19.46│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 3 │9.55│ 9.28│ 9.12│ 8.84│8.76│ 8.71│'); writeln(' 8.69│ 8.66│ 8.64│ 8.62│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 4 │6.94│ 6.59│ 6.39│ 6.04│5.93│ 5.87│'); writeln(' 5.84│ 5.8 │ 5.77│ 5.74│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 5 │5.79│ 5.41│ 5.19│ 4.82│ 4.7│ 4.64│'); writeln(' 4.6 │ 4.56│ 4.53│ 4.5 │'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 6 │5.14│ 4.76│ 4.53│ 4.15│4.03│ 3.96│'); writeln(' 3.92│ 3.87│ 3.84│ 3.81│');
203
write('└───┴────┴─────┴─────┴─────┴────┴─────┴'); writeln('─────┴─────┴─────┴─────┘'); end; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────────'); writeln(F0,'─────────────────┐'); write(F0,'│ │ Значение'); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬────'); writeln(F0,'──────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ '); writeln(F0,'L(J) │ Z(J) │'); end; if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10); writeln(F0,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│');
204
writeln(F0,L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; end; end.
205
Программа NW5(три модуля tpg3, _Х=5_, _Х=25_, «система» после «адекватно»)… program tpg3_1; {Математическое моделирование} uses tpg3_3, tpg3_2; label 1,2,3,4,5; procedure VV_DAN; begin case X of 5: begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); end; 25:begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; end;{case} end;{VV_DAN}
206
procedure OUT_Z_B; begin writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln(F0,(Y[J]-Z[J]):10,'│'); write('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln((Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {================================================================ Основная программа =================================================================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из трех'); writeln(' файлов tpg3_1,tpg3_2,tpg3_3(nw5_1,nw5_2,nw5-3). Математическое'); writeln('моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программы GGN3.'); writeln(' Разработка Черного А.А.'); writeln(' Autor Chernyy Anatoly Alekseevech'); writeln('Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,'Выполнение программы математического моделирования'); writeln(F0,' tpg3_1(nw5_1). (Программа на языке Турбо-Паскаль).'); writeln(F0,' Autor Chernyy Anatoly Alekseevech'); writeln('_X=5_,_X=25_'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; VV_DAN; if X=0 then goto 2; PR_MOD; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение и'); writeln('ввод величин показателей Y(J)');
207
write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y(J)'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 5: GB4290; 25:begin GB4290; GB4340; end; end;{case} GB1410; case X of 5: begin GB2000; GB2020; end; 25:begin GB1480; GB1600; GB1670; GB1730; GB1830; end; end; writeln('B(J) до анализа'); writeln(F0,'B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 5: GB4420; 25:GB4690; else goto 2; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=30 then goto 3; if I0=25 then begin GB4880; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'Количество опытов на среднем уровне факторов N0=',N0);
208
writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if not(I0=5) then begin writeln('Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'Табличный T-критерий T0=',T0:5:3); writeln('B(J) после анализа'); writeln(F0,'B(J) после анализа'); for J:=1 to X do begin if T[J]
209
writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; K9:=0; for J:=1 to X do begin if B[J]=0 then K9:=K9+1; end; writeln('Количество статистически значимых'); writeln('коэффициентов регрессии'); writeln('K9=',K9); writeln('F9=X-1'); F9:=X-1; writeln('F9=',F9); writeln(F0,'Количество статистически значимых'); writeln(F0,'коэффициентов регрессии'); writeln(F0,'K9=',K9); writeln(F0,'F9=X-1'); F9:=X-1; writeln(F0,'F9=',F9); tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 5: GB4420; 25:GB4690; else goto 2; end; writeln('Расчетные величины показателя'); writeln('Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; if X=25 then begin
210
writeln(F0,'X=25. System, 1.1 - 10.5, finish 10.5.'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'C1=',C1,'Z(16)=',Z[16]); writeln(F0,'1.3.','A2=',A2,'E1=',E1,'Z(7)=',Z[7]); writeln(F0,'1.4.','A2=',A2,'D1=',D1,'Z(21)=',Z[21]); writeln(F0,'1.5.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','C2=',C2,'A1=',A1,'Z(10)=',Z[10]); writeln(F0,'2.2.','C2=',C2,'C1=',C1,'Z(17)=',Z[17]); writeln(F0,'2.3.','C2=',C2,'E1=',E1,'Z(14)=',Z[14]); writeln(F0,'2.4.','C2=',C2,'D1=',D1,'Z(22)=',Z[22]); writeln(F0,'2.5.','C2=',C2,'B1=',B1,'Z(13)=',Z[13]); writeln(F0,'3.1.','E2=',E2,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'3.2.','E2=',E2,'C1=',C1,'Z(18)=',Z[18]); writeln(F0,'3.3.','E2=',E2,'E1=',E1,'Z(9)=',Z[9]); writeln(F0,'3.4.','E2=',E2,'D1=',D1,'Z(23)=',Z[23]); writeln(F0,'3.5.','E2=',E2,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'4.1.','D2=',D2,'A1=',A1,'Z(12)=',Z[12]); writeln(F0,'4.2.','D2=',D2,'C1=',C1,'Z(19)=',Z[19]); writeln(F0,'4.3.','D2=',D2,'E1=',E1,'Z(15)=',Z[15]); writeln(F0,'4.4.','D2=',D2,'D1=',D1,'Z(24)=',Z[24]); writeln(F0,'4.5.','D2=',D2,'B1=',B1,'Z(11)=',Z[11]); writeln(F0,'5.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'5.2.','B2=',B2,'C1=',C1,'Z(20)=',Z[20]); writeln(F0,'5.3.','B2=',B2,'E1=',E1,'Z(8)=',Z[8]); writeln(F0,'5.4.','B2=',B2,'D1=',D1,'Z(25)=',Z[25]); writeln(F0,'5.5.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'6.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'6.2.','A1=',A1,'C2=',C2,'Z(10)=',Z[10]); writeln(F0,'6.3.','A1=',A1,'E2=',E2,'Z(5)=',Z[5]); writeln(F0,'6.4.','A1=',A1,'D2=',D2,'Z(12)=',Z[12]); writeln(F0,'6.5.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'7.1.','C1=',C1,'A2=',A2,'Z(16)=',Z[16]); writeln(F0,'7.2.','C1=',C1,'C2=',C2,'Z(17)=',Z[17]); writeln(F0,'7.3.','C1=',C1,'E2=',E2,'Z(18)=',Z[18]); writeln(F0,'7.4.','C1=',C1,'D2=',D2,'Z(19)=',Z[19]); writeln(F0,'7.5.','C1=',C1,'B2=',B2,'Z(20)=',Z[20]); writeln(F0,'8.1.','E1=',E1,'A2=',A2,'Z(7)=',Z[7]); writeln(F0,'8.2.','E1=',E1,'C2=',C2,'Z(14)=',Z[14]); writeln(F0,'8.3.','E1=',E1,'E2=',E2,'Z(9)=',Z[9]); writeln(F0,'8.4.','E1=',E1,'D2=',D2,'Z(15)=',Z[15]); writeln(F0,'8.5.','E1=',E1,'B2=',B2,'Z(8)=',Z[8]); writeln(F0,'9.1.','D1=',D1,'A2=',A2,'Z(21)=',Z[21]); writeln(F0,'9.2.','D1=',D1,'C2=',C2,'Z(22)=',Z[22]); writeln(F0,'9.3.','D1=',D1,'E2=',E2,'Z(23)=',Z[23]); writeln(F0,'9.4.','D1=',D1,'D2=',D2,'Z(24)=',Z[24]); writeln(F0,'9.5.','D1=',D1,'B2=',B2,'Z(25)=',Z[25]); writeln(F0,'10.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'10.2.','B1=',B1,'C2=',C2,'Z(13)=',Z[13]); writeln(F0,'10.3.','B1=',B1,'E2=',E2,'Z(6)=',Z[6]); writeln(F0,'10.4.','B1=',B1,'D2=',D2,'Z(11)=',Z[11]); writeln(F0,'10.5.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); end; if X=5 then begin writeln(F0,'X=5. System, 1.1 - 1.5, finish 1.5.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','C1=',C1,'Z(3)=',Z[3]);
211
writeln(F0,'1.3.','E1=',E1,'Z(5)=',Z[5]); writeln(F0,'1.4.','D1=',D1,'Z(4)=',Z[4]); writeln(F0,'1.5.','B1=',B1,'Z(2)=',Z[2]); end; case X of 5: OUT_F_H_L(73); 25:OUT_F_H_L(74); end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB4880; goto 2; end; if I0=22 then begin GB7000; goto 2; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S) - 1,2,3 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S) - 1,2,3 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'расчеты по модели'); if (X=5) then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); case X of 5: begin GB4290; GB4420; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(73); end;{if} if (X=16) then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; H[S]:=0;
212
writeln('Ввод F(',S,')',' H(',S,')'); readln(F[S],H[S]); case X of 25:begin GB4290; GB4340; GB4690; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(74); end;{if} 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if I0=11 then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end.{Конец программы} unit TPG3_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2:real; T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0: Text; procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); function ste(Q,A:real):real; procedure GB1410; procedure GB1480; procedure GB1600; procedure GB1670; procedure GB1730; procedure GB1830; procedure GB2000; procedure GB2020;
213
procedure GB4290; procedure GB4340; procedure GB4420; procedure GB4690; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then begin A:=abs(A); if Q=0 then Q:=1E-5; ste:=1/exp(A*ln(Q)); end else begin if Q=0 then Q:=1E-5; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure GB1410; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+K[J]*Y[J]; O[3]:=O[3]+K[J]*K[J]; end; B[3]:=SS/O[3]; end;{GB1410} procedure GB1480; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[4]:=O[4]+P[J]*P[J]; end; B[4]:=SS/O[4]; SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[5]:=O[5]+(I[J]*P[J])*(I[J]*P[J]); end; B[5]:=SS/O[5]; SS:=0; O[6]:=0;
214
for J:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[6]:=O[6]+Q[J]*Q[J]; end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[7]:=O[7]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*Y[J]; O[8]:=O[8]+(P[J]*K[J])*(P[J]*K[J]); end; B[8]:=SS/O[8]; SS:=0; O[9]:=0; for J:=1 to X do begin SS:=SS+K[J]*Q[J]*Y[J]; O[9]:=O[9]+(K[J]*Q[J])*(K[J]*Q[J]); end; B[9]:=SS/O[9]; end;{GB1480} procedure GB1600; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+K[J]*U[J]*Y[J]; O[12]:=O[12]+K[J]*U[J]*K[J]*U[J]; end; B[12]:=SS/O[12]; end;{GB1600} procedure GB1670; begin SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[13]:=O[13]+V[J]*V[J]; end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do
215
begin SS:=SS+I[J]*V[J]*Y[J]; O[14]:=O[14]+I[J]*V[J]*I[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J]; O[15]:=O[15]+K[J]*V[J]*K[J]*V[J]; end; B[15]:=SS/O[15]; end;{GB1670} procedure GB1730; begin SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[16]:=O[16]+L[J]*L[J]; end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+P[J]*L[J]*Y[J]; O[17]:=O[17]+(P[J]*L[J])*(P[J]*L[J]); end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+Q[J]*L[J]*Y[J]; O[18]:=O[18]+(Q[J]*L[J])*(Q[J]*L[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+L[J]*U[J]*Y[J]; O[19]:=O[19]+(L[J]*U[J])*(L[J]*U[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+L[J]*V[J]*Y[J]; O[20]:=O[20]+(L[J]*V[J])*(L[J]*V[J]); end; B[20]:=SS/O[20]; end;{GB1730} procedure GB1830; begin SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+M[J]*Y[J]; O[21]:=O[21]+M[J]*M[J]; end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin
216
SS:=SS+P[J]*M[J]*Y[J]; O[22]:=O[22]+(P[J]*M[J])*(P[J]*M[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*M[J]*Y[J]; O[23]:=O[23]+(Q[J]*M[J])*(Q[J]*M[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+U[J]*M[J]*Y[J]; O[24]:=O[24]+(U[J]*M[J])*(U[J]*M[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+M[J]*V[J]*Y[J]; O[25]:=O[25]+(M[J]*V[J])*(M[J]*V[J]); end; B[25]:=SS/O[25]; end;{GB1830} procedure GB2000; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[4]:=O[4]+L[J]*L[J]; end; B[4]:=SS/O[4]; end;{GB2000} procedure GB2020; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+M[J]*Y[J]; O[5]:=O[5]+M[J]*M[J]; end; B[5]:=SS/O[5]; end;{GB2020} procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); var N0,R0,S0,W0,L2,N3,K2,R3,M2,S3,N4,N5:real; N6,N7,N8,N9,R4,R5,R6,R7,S4,S5,P0:real; Z1,Z2,Z3,Z4,Z5,Z6,Z7,Z0,Z8,Z9,T7:real; T8,T9,G3,G4,G5,G6,G7:real; begin N0:=(ste(A,N)+ste(B,N)+ste(C,N)+ste(D,N)+ste(E,N))/5; R0:=(ste(A,R)+ste(B,R)+ste(C,R)+ste(D,R)+ste(E,R))/5; S0:=(ste(A,S)+ste(B,S)+ste(C,S)+ste(D,S)+ste(E,S))/5; W0:=(ste(A,W)+ste(B,W)+ste(C,W)+ste(D,W)+ste(E,W))/5; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(C,L2)+ste(D,L2)+ste(E,L2))/5;
217
K2:=2*R; R3:=(ste(A,K2)+ste(B,K2)+ste(C,K2)+ste(D,K2)+ste(E,K2))/5; M2:=2*S; S3:=(ste(A,M2)+ste(B,M2)+ste(C,M2)+ste(D,M2)+ste(E,M2))/5; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(C,N4)+ste(D,N4)+ste(E,N4))/5; N6:=N+S; N7:=(ste(A,N6)+ste(B,N6)+ste(C,N6)+ste(D,N6)+ste(E,N6))/5; N8:=N+W; N9:=(ste(A,N8)+ste(B,N8)+ste(C,N8)+ste(D,N8)+ste(E,N8))/5; R4:=R+S; R5:=(ste(A,R4)+ste(B,R4)+ste(C,R4)+ste(D,R4)+ste(E,R4))/5; R6:=R+W; R7:=(ste(A,R6)+ste(B,R6)+ste(C,R6)+ste(D,R6)+ste(E,R6))/5; S4:=S+W; S5:=(ste(A,S4)+ste(B,S4)+ste(C,S4)+ste(D,S4)+ste(E,S4))/5; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); P0:=(N0*S0-N7)/(N3-N0*N0); Z1:=R0*S0-R5+P0*(N0*R0-N5); Z2:=U0*(N0*S0-N7)+U0*P0*(N0*N0-N3); Z3:=R3-R0*R0+2*U0*(N5-N0*R0); I0:=(Z1+Z2)/(Z3+(N3-N0*N0)*U0*U0); M0:=I0*U0+P0; F0:=-(S0+I0*R0+M0*N0); Z4:=R0+U0*N0; Z5:=Z4*N0-N5-U0*N3; Z6:=R3+U0*N5-Z4*R0-Z5*U0; Z7:=Z4*S0+Z5*P0-R5-U0*N7; Z0:=(N0*W0-N9)/(N3-N0*N0); Z8:=Z5*Z0+Z4*W0-R7-U0*N9; Z9:=S3+I0*R5+M0*N7; T7:=R5+I0*R3+M0*N5; T8:=N7+I0*N5+M0*N3; T9:=S0+I0*R0+M0*N0; G3:=S5+I0*R7+M0*N9; G4:=T9*N0-T8; G5:=Z9-T9*S0-G4*P0; G6:=T9*R0-T7+G4*U0; G7:=G4*Z0+T9*W0-G3; G0:=(Z6*G7+Z8*G6)/(Z6*G5-Z7*G6); H0:=(G0*Z7+Z8)/Z6; K0:=G0*P0+H0*U0+Z0; L0:=-(W0+G0*S0+H0*R0+K0*N0); end;{GB3860} procedure GB4290; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; L[J]:=ste(F[J],P1)+I1*ste(F[J],O1)+M1*ste(F[J],J1)+F1; M[J]:=ste(F[J],T1)+G1*ste(F[J],P1)+H1*ste(F[J],O1) +K1*ste(F[J],J1)+L1; end; end;{GB4290}
218
procedure GB4340; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; U[J]:=ste(H[J],P2)+I2*ste(H[J],O2)+M2*ste(H[J],J2)+F2; V[J]:=ste(H[J],T2)+G2*ste(H[J],P2)+H2*ste(H[J],O2) +K2*ste(H[J],J2)+L2; end; end;{GB4340} procedure GB4420; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*L[J]+B[5]*M[J]; end;{GB4420} procedure GB4690; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]+B[15]*K[J]*V[J]; N7:=B[16]*L[J]+B[17]*P[J]*L[J]+B[18]*Q[J]*L[J]+B[19]*L[J]*U[J]; R3:=B[20]*L[J]*V[J]+B[21]*M[J]+B[22]*P[J]*M[J]; R4:=B[23]*Q[J]*M[J]+B[24]*U[J]*M[J]+B[25]*M[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R3+R4; end; end;{GB4690} end. unit TPG3_3; Interface uses tpg3_2; var grMode: Integer; procedure PR_MOD; procedure GB4880; procedure GB7000; procedure VVOD51; procedure VVOD52; procedure tablF9; procedure OUT_F_H_L(PR:integer); Implementation procedure VVOD51; begin writeln('Ввод A1 C1 E1 D1 B1 J1 O1 P1 T1'); readln(A1,C1,E1,D1,B1,J1,O1,P1,T1); writeln(F0,'A1=',A1,' C1=',C1,' E1=',E1); writeln(F0,'D1=',D1,' B1=',B1,' J1=',J1); writeln(F0,'O1=',O1,' P1=',P1,' T1=',T1); end;{VVOD51} procedure VVOD52; begin writeln('Ввод A2 C2 E2 D2 B2 J2 O2 P2 T2'); readln(A2,C2,E2,D2,B2,J2,O2,P2,T2); writeln(F0,'A2=',A2,' C2=',C2,' E2=',E2); writeln(F0,'D2=',D2,' B2=',B2,' J2=',J2); writeln(F0,'O2=',O2,' P2=',P2,' T2=',T2);
219
end;{VVOD52} procedure PR_MOD; begin case X of 5: begin F[1]:=A1; F[2]:=B1; F[3]:=C1; F[4]:=D1; F[5]:=E1; end 25:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; F[10]:=A1; H[10]:=C2; F[11]:=B1; H[11]:=D2; F[12]:=A1; H[12]:=D2; F[13]:=B1; H[13]:=C2; F[14]:=E1; H[14]:=C2; F[15]:=E1; H[15]:=D2; F[16]:=C1; H[16]:=A2; F[17]:=C1; H[17]:=C2; F[18]:=C1; H[18]:=E2; F[19]:=C1; H[19]:=D2; F[20]:=C1; H[20]:=B2; F[21]:=D1; H[21]:=A2; F[22]:=D1; H[22]:=C2; F[23]:=D1; H[23]:=E2; F[24]:=D1; H[24]:=D2; F[25]:=D1; H[25]:=B2; end; end; end; procedure GB4880; begin writeln(F0,'Математическая модель'); if X=5 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*L(J)+',B[5]:10,'*M(J),'); end; if X=25 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*Q(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*L(J)+',B[17]:10,'*P(J)*L(J)+'); writeln(F0,'+',B[18]:10,'*Q(J)*L(J)+',B[19]:10,'*L(J)*U(J)+'); writeln(F0,'+',B[20]:10,'*L(J)*V(J)+',B[21]:10,'*M(J)+'); writeln(F0,'+',B[22]:10,'*P(J)*M(J)+',B[23]:10,'*Q(J)*M(J)+'); writeln(F0,'+',B[24]:10,'*U(J)*M(J)+',B[25]:10,'*M(J)*V(J),'); end; if (X=5)or(X=25) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=5)or(X=25) then begin writeln(F0,'L(J)=F(J)^',P1:10,'+',I1:10,'*F(J)^',O1:10,'+'); writeln(F0,'+',M1:10,'F(J)^',J1:10,'+',F1:10); end; if (X=5)or(X=25) then begin
220
writeln(F0,'M(J)=F(J)^',T1:10,'+',G1:10,'*F(J)^',P1:10,'+'); writeln(F0,'+',H1:10,'*F(J)^',O1:10,'+',K1:10,'*F(J)^',I1:10,'+',L1:10); end; if (X=25) then begin writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,','); writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10,','); writeln(F0,'U(J)=H(J)^',P2:10,'+',I2:10,'*H(J)^',O2:10,'+'); writeln(F0,'+',M2:10,'*H(J)^',J2:10,'+',F2:10); end; if (X=25) then begin writeln(F0,'V(J)=H(J)^',T2:10,'+',G2:10,'*H(J)^',P2:10,'+'); writeln(F0,'+',H2:10,'*H(J)^',O2:10,'+',K2:10,'*H(J)^',J2:10,'+'); writeln(F0,'+',L2:10); end; end;{GB4880} procedure GB7000; label 1; begin repeat writeln('vvod X'); readln(X); writeln('X=',X); writeln(F0,'X=',X); if (X=5) then I0:=61; if (X=25) then I0:=62; if I0=61 then begin case X of 5: I0:=75; end; F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end;{for} case I0 of 75:begin GB4290; GB4420; end; end;{case} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]);
221
OUT_F_H_L(73); end;{if} if I0=62 then begin case X of 25:I0:=81; end; F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); case I0 of 81:begin GB4290; GB4340; GB4690; end; end;{case} writeln('Z(',K5,')=',Z[K5]); end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(74); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); writeln(F0,'Выявление MAX Z(K5) и MIN Z(K5)'); K8:=0; K8:=Z[1]; for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; begin writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); end; for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]);
222
writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; begin writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); end; for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000} procedure tablF9; begin write(' Значения F7 для 5% уровня'); writeln('значимости'); write('┌───┬──────────────────────────────────'); writeln('───────────────────────┐'); write('│ │ F9 '); writeln(' │'); write('│F8 ├────┬─────┬─────┬─────┬────┬─────┬'); writeln('─────┬─────┬─────┬─────┤'); write('│ │ 2 │ 3 │ 4 │ 8 │ 11 │ 14 │'); writeln('15-16│19-20│ 24 │26-30│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤');
223
write('│ 2 │19.0│19.16│19.25│19.37│19.4│19.42│'); writeln('19.43│19.44│19.45│19.46│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 3 │9.55│ 9.28│ 9.12│ 8.84│8.76│ 8.71│'); writeln(' 8.69│ 8.66│ 8.64│ 8.62│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 4 │6.94│ 6.59│ 6.39│ 6.04│5.93│ 5.87│'); writeln(' 5.84│ 5.8 │ 5.77│ 5.74│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 5 │5.79│ 5.41│ 5.19│ 4.82│ 4.7│ 4.64│'); writeln(' 4.6 │ 4.56│ 4.53│ 4.5 │'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 6 │5.14│ 4.76│ 4.53│ 4.15│4.03│ 3.96│'); writeln(' 3.92│ 3.87│ 3.84│ 3.81│'); write('└───┴────┴─────┴─────┴─────┴────┴─────┴'); writeln('─────┴─────┴─────┴─────┘'); end; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10); writeln(F0,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end;
224
write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; end; end.
225
Программа NW6 (три модуля tpg3, _Х=3_, _Х=4_, _Х=5_, _Х=12_, _Х=15_, Х=9, Х=16, Х=20, Х=25, Х=27 «система» после «адекватно»)… program tpg3_1; {Математическое моделирование} uses tpg3_3, tpg3_2; label 1,2,3,4,5; procedure VV_DAN; begin case X of 4: begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); end; 16:begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); VVOD42; GB3710(A2,B2,C2,D2,J2,O2,P2,V2,U2,Q2,I2,M2,F2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); end; 20:begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2);
226
writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 5: begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); end; 25:begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 15:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD52;
227
GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 3: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); end; 12:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD42; GB3710(A2,C2,D2,B2,J2,O2,P2,V2,U2,Q2,I2,M2,F2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); end; 9: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); end; 27:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1);
228
writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); VVOD33; GB3660(A3,E3,B3,J3,O3,V3,U3,Q3); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V3=',V3,' U3=',U3,' Q3=',Q3); writeln(F0,'V3=',V3,' U3=',U3,' Q3=',Q3); end; end;{case} end;{VV_DAN} procedure OUT_Z_B; begin writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln(F0,(Y[J]-Z[J]):10,'│'); write('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln((Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {================================================================ Основная программа =================================================================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из трех'); writeln(' файлов tpg3_1,tpg3_2,tpg3_3(nw6_1,nw6_2,nw6_3). Математическое'); writeln('моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программы GGN3.'); writeln(' Разработка Черного А.А.'); writeln(' Autor Chernyy Anatoly Alekseevech'); writeln('Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,'Выполнение программы математического моделирования'); writeln(F0,' tpg3_1(nw6_1). (Программа на языке Турбо-Паскаль).'); writeln(F0,' Autor Chernyy Anatoly Alekseevech'); writeln('_X=3_,_X=4_,_X=5_,X=12_,_X=15_'); writeln('_X=3_,_X=4_,_X=5_,X=9,_X=12_,_X=15_,X=16,X=20,X=25,X=27'); J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0;
229
J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; VV_DAN; if X=0 then goto 2; PR_MOD; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение и'); writeln('ввод величин показателей Y(J)'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y(J)'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 3: GB4150; 4: GB4210; 5: GB4290; 9: begin GB4150; GB4170; end; 12:begin GB4150; GB4250; end; 15:begin GB4150; GB4340; end; 16:begin GB4210; GB4250; end; 20:begin GB4210; GB4340; end; 25:begin GB4290; GB4340; end; 27:begin GB4150; GB4170; GB4190; end; end;{case} GB1410; case X of 4: GB2000; 5: begin GB2000; GB2020; end;
230
9: begin GB1480; end; 12:begin GB1480; GB1600; end; 15:begin GB1480; GB1600; GB1670; end; 16:begin GB1480; GB1600; GB1930; end; 20:begin GB1480; GB1600; GB1670; GB1730; end; 25:begin GB1480; GB1600; GB1670; GB1730; GB1830; end; 27:begin GB1480; GB2040; end; end; writeln('B(J) до анализа'); writeln(F0,'B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 3: GB4390; 4: GB4400; 5: GB4420; 9: GB4450; 12:GB4490; 15:GB4530; 16:GB4580; 20:GB4630; 25:GB4690; 27:GB4770; else goto 2; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=30 then goto 3; if I0=25 then begin GB4880; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'Количество опытов на среднем уровне факторов N0=',N0); writeln('Ввод F8=N0-1'); readln(F8); writeln(F0,'F8=N0-1=',F8); end; if I0=3 then
231
begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if not(I0=5) then begin writeln('Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'Табличный T-критерий T0=',T0:5:3); writeln('B(J) после анализа'); writeln(F0,'B(J) после анализа'); for J:=1 to X do begin if T[J]
232
begin if B[J]=0 then K9:=K9+1; end; writeln('Количество статистически значимых'); writeln('коэффициентов регрессии'); writeln('K9=',K9); writeln('F9=X-1'); F9:=X-1; writeln('F9=',F9); writeln(F0,'Количество статистически значимых'); writeln(F0,'коэффициентов регрессии'); writeln(F0,'K9=',K9); writeln(F0,'F9=X-1'); F9:=X-1; writeln(F0,'F9=',F9); tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 3: GB4390; 4: GB4400; 5: GB4420; 9: GB4450; 12:GB4490; 15:GB4530; 16:GB4580; 20:GB4630; 25:GB4690; 27:GB4770; else goto 2; end; writeln('Расчетные величины показателя'); writeln('Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7');
233
end; if X=3 then begin writeln(F0,'X=3. System, 1.1 - 1.3, finish 1.3.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','E1=',E1,'Z(3)=',Z[3]); writeln(F0,'1.3.','B1=',B1,'Z(2)=',Z[2]); end; if X=4 then begin writeln(F0,'X=4. System, 1.1 - 1.4, finish 1.4.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','C1=',C1,'Z(3)=',Z[3]); writeln(F0,'1.3.','D1=',D1,'Z(4)=',Z[4]); writeln(F0,'1.4.','B1=',B1,'Z(2)=',Z[2]); end; if X=12 then begin writeln(F0,'X=12. System, 1.1 - 7.4, finish 7.4'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'E1=',E1,'Z(5)=',Z[5]); writeln(F0,'1.3.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','C2=',C2,'A1=',A1,'Z(7)=',Z[7]); writeln(F0,'2.2.','C2=',C2,'E1=',E1,'Z(11)=',Z[11]); writeln(F0,'2.3.','C2=',C2,'B1=',B1,'Z(10)=',Z[10]); writeln(F0,'3.1.','D2=',D2,'A1=',A1,'Z(9)=',Z[9]); writeln(F0,'3.2.','D2=',D2,'E1=',E1,'Z(12)=',Z[12]); writeln(F0,'3.3.','D2=',D2,'B1=',B1,'Z(8)=',Z[8]); writeln(F0,'4.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'4.2.','B2=',B2,'E1=',E1,'Z(6)=',Z[6]); writeln(F0,'4.3.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'5.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'5.2.','A1=',A1,'C2=',C2,'Z(7)=',Z[7]); writeln(F0,'5.3.','A1=',A1,'D2=',D2,'Z(9)=',Z[9]); writeln(F0,'5.4.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'6.1.','E1=',E1,'A2=',A2,'Z(5)=',Z[5]); writeln(F0,'6.2.','E1=',E1,'C2=',C2,'Z(11)=',Z[11]); writeln(F0,'6.3.','E1=',E1,'D2=',D2,'Z(12)=',Z[12]); writeln(F0,'6.4.','E1=',E1,'B2=',B2,'Z(6)=',Z[6]); writeln(F0,'7.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'7.2.','B1=',B1,'C2=',C2,'Z(10)=',Z[10]); writeln(F0,'7.3.','B1=',B1,'D2=',D2,'Z(8)=',Z[8]); writeln(F0,'7.4.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); end; if X=15 then begin writeln(F0,'X=15. System, 1.1 - 8.5, finish 8.5.'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'E1=',E2,'Z(7)=',Z[7]); writeln(F0,'1.3.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','C2=',C2,'A1=',A1,'Z(10)=',Z[10]); writeln(F0,'2.2.','C2=',C2,'E1=',E1,'Z(14)=',Z[14]); writeln(F0,'2.3.','C2=',C2,'B1=',B1,'Z(13)=',Z[13]); writeln(F0,'3.1.','E2=',E2,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'3.2.','E2=',E2,'E1=',E1,'Z(9)=',Z[9]); writeln(F0,'3.3.','E2=',E2,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'4.1.','D2=',D2,'A1=',A1,'Z(12)=',Z[12]);
234
writeln(F0,'4.2.','D2=',D2,'E1=',E1,'Z(15)=',Z[15]); writeln(F0,'4.3.','D2=',D2,'B1=',B1,'Z(11)=',Z[11]); writeln(F0,'5.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'5.2.','B2=',B2,'E1=',E1,'Z(8)=',Z[8]); writeln(F0,'5.3.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'6.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'6.2.','A1=',A1,'C2=',C2,'Z(10)=',Z[10]); writeln(F0,'6.3.','A1=',A1,'E2=',E2,'Z(5)=',Z[5]); writeln(F0,'6.4.','A1=',A1,'D2=',D2,'Z(12)=',Z[12]); writeln(F0,'6.5.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'7.1.','E1=',E1,'A2=',A2,'Z(7)=',Z[7]); writeln(F0,'7.2.','E1=',E1,'C2=',C2,'Z(14)=',Z[14]); writeln(F0,'7.3.','E1=',E1,'E2=',E2,'Z(9)=',Z[9]); writeln(F0,'7.4.','E1=',E1,'D2=',D2,'Z(15)=',Z[15]); writeln(F0,'7.5.','E1=',E1,'B2=',B2,'Z(8)=',Z[8]); writeln(F0,'8.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'8.2.','B1=',B1,'C2=',C2,'Z(13)=',Z[13]); writeln(F0,'8.3.','B1=',B1,'E2=',E2,'Z(6)=',Z[6]); writeln(F0,'8.4.','B1=',B1,'D2=',D2,'Z(11)=',Z[11]); writeln(F0,'8.5.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); end; if X=5 then begin writeln(F0,'X=5. System, 1.1 - 1.5, finish 1.5.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','C1=',C1,'Z(3)=',Z[3]); writeln(F0,'1.3.','E1=',E1,'Z(5)=',Z[5]); writeln(F0,'1.4.','D1=',D1,'Z(4)=',Z[4]); writeln(F0,'1.5.','B1=',B1,'Z(2)=',Z[2]); end; case X of 3: OUT_F_H_L(73); 4: OUT_F_H_L(73); 5: OUT_F_H_L(73); 9: OUT_F_H_L(74); 12:OUT_F_H_L(74); 15:OUT_F_H_L(74); 16:OUT_F_H_L(74); 20:OUT_F_H_L(74); 25:OUT_F_H_L(74); 27:OUT_F_H_L(75); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов и построение графиков'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1;
235
if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB4880; goto 2; end; if I0=22 then begin GB7000; goto 2; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S) - 1,2,3 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S) - 1,2,3 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'расчеты по модели'); if (X=3)or(X=4)or(X=5)then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); case X of 3: begin GB4150; GB4390; end; 4: begin GB4210; GB4400; end; 5: begin GB4290; GB4420; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(73); end;{if} if (X=9)or(X=12)or(X=15)or(X=16)or(X=20)or(X=25)then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; H[S]:=0; writeln('Ввод F(',S,')',' H(',S,')'); readln(F[S],H[S]); case X of 9: begin GB4150; GB4170; GB4450; end; 12:begin GB4150; GB4250; GB4490; end; 15:begin GB4150; GB4340; GB4530; end; 16:begin GB4210; GB4250; GB4580; end; 20:begin
236
GB4210; GB4340; GB4630; end; 25:begin GB4290; GB4340; GB4690; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(74); end;{if} if X=27 then begin for S:=1 to X do begin writeln('Ввод F(',S,')',' H(',S,')',' L(',S,')'); readln(F[S],H[S],L[S]); GB4150; GB4170; GB4190; GB4770; writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(75); end;{if} 2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов и построение графиков'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if I0=11 then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end.{Конец программы} unit TPG3_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6:real;
237
J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2:real; T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0: Text; procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); procedure GB3710(A,B,C,D,N,R,S:real; var V0,U0,Q0,I0,M0,F0:real); procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); function ste(Q,A:real):real; procedure GB1410; procedure GB1480; procedure GB1600; procedure GB1670; procedure GB1730; procedure GB1830; procedure GB1930; procedure GB2000; procedure GB2020; procedure GB2040; procedure GB4150; procedure GB4210; procedure GB4290; procedure GB4170; procedure GB4190; procedure GB4250; procedure GB4340; procedure GB4400; procedure GB4420; procedure GB4450; procedure GB4490; procedure GB4530; procedure GB4580; procedure GB4630; procedure GB4690; procedure GB4390; procedure GB4770; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin if A<0 then begin A:=abs(A); if Q=0 then Q:=1E-5; ste:=1/exp(A*ln(Q)); end else begin if Q=0 then Q:=1E-5; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure GB1410; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+K[J]*Y[J]; O[3]:=O[3]+K[J]*K[J]; end; B[3]:=SS/O[3]; end;{GB1410} procedure GB1480;
238
begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[4]:=O[4]+P[J]*P[J]; end; B[4]:=SS/O[4]; SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[5]:=O[5]+(I[J]*P[J])*(I[J]*P[J]); end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[6]:=O[6]+Q[J]*Q[J]; end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*Y[J]; O[7]:=O[7]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*Y[J]; O[8]:=O[8]+(P[J]*K[J])*(P[J]*K[J]); end; B[8]:=SS/O[8]; SS:=0; O[9]:=0; for J:=1 to X do begin SS:=SS+K[J]*Q[J]*Y[J]; O[9]:=O[9]+(K[J]*Q[J])*(K[J]*Q[J]); end; B[9]:=SS/O[9]; end;{GB1480} procedure GB1600; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+K[J]*U[J]*Y[J];
239
O[12]:=O[12]+K[J]*U[J]*K[J]*U[J]; end; B[12]:=SS/O[12]; end;{GB1600} procedure GB1670; begin SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[13]:=O[13]+V[J]*V[J]; end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[14]:=O[14]+I[J]*V[J]*I[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J]; O[15]:=O[15]+K[J]*V[J]*K[J]*V[J]; end; B[15]:=SS/O[15]; end;{GB1670} procedure GB1730; begin SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[16]:=O[16]+L[J]*L[J]; end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+P[J]*L[J]*Y[J]; O[17]:=O[17]+(P[J]*L[J])*(P[J]*L[J]); end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+Q[J]*L[J]*Y[J]; O[18]:=O[18]+(Q[J]*L[J])*(Q[J]*L[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+L[J]*U[J]*Y[J]; O[19]:=O[19]+(L[J]*U[J])*(L[J]*U[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+L[J]*V[J]*Y[J]; O[20]:=O[20]+(L[J]*V[J])*(L[J]*V[J]);
240
end; B[20]:=SS/O[20]; end;{GB1730} procedure GB1830; begin SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+M[J]*Y[J]; O[21]:=O[21]+M[J]*M[J]; end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+P[J]*M[J]*Y[J]; O[22]:=O[22]+(P[J]*M[J])*(P[J]*M[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*M[J]*Y[J]; O[23]:=O[23]+(Q[J]*M[J])*(Q[J]*M[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+U[J]*M[J]*Y[J]; O[24]:=O[24]+(U[J]*M[J])*(U[J]*M[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+M[J]*V[J]*Y[J]; O[25]:=O[25]+(M[J]*V[J])*(M[J]*V[J]); end; B[25]:=SS/O[25]; end;{GB1830} procedure GB1930; begin SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[13]:=O[13]+L[J]*L[J]; end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+P[J]*L[J]*Y[J]; O[14]:=O[14]+(P[J]*L[J])*(P[J]*L[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+Q[J]*L[J]*Y[J]; O[15]:=O[15]+(Q[J]*L[J])*(Q[J]*L[J]); end;
241
B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+L[J]*U[J]*Y[J]; O[16]:=O[16]+(L[J]*U[J])*(L[J]*U[J]); end; B[16]:=SS/O[16]; end;{GB1930} procedure GB2000; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[4]:=O[4]+L[J]*L[J]; end; B[4]:=SS/O[4]; end;{GB2000} procedure GB2020; begin SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+M[J]*Y[J]; O[5]:=O[5]+M[J]*M[J]; end; B[5]:=SS/O[5]; end;{GB2020} procedure GB2040; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[12]:=O[12]+(P[J]*U[J])*(P[J]*U[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[13]:=O[13]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin
242
SS:=SS+V[J]*Y[J]; O[14]:=O[14]+V[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[15]:=O[15]+(I[J]*V[J])*(I[J]*V[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[16]:=O[16]+(P[J]*V[J])*(P[J]*V[J]); end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Y[J]; O[17]:=O[17]+(U[J]*K[J])*(U[J]*K[J]); end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[18]:=O[18]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[19]:=O[19]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[20]:=O[20]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*K[J]*Y[J]; O[21]:=O[21]+(P[J]*U[J]*K[J])*(P[J]*U[J]*K[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J]; O[22]:=O[22]+(K[J]*V[J])*(K[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[23]:=O[23]+(Q[J]*V[J])*(Q[J]*V[J]); end;
243
B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*V[J]*Y[J]; O[25]:=O[25]+(P[J]*K[J]*V[J])*(P[J]*K[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Q[J]*Y[J]; O[26]:=O[26]+(U[J]*K[J]*Q[J])*(U[J]*K[J]*Q[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin SS:=SS+K[J]*Q[J]*V[J]*Y[J]; O[27]:=O[27]+(K[J]*Q[J]*V[J])*(K[J]*Q[J]*V[J]); end; B[27]:=SS/O[27]; end;{GB2040} procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); var L2,N0,R0,N3,N4,N5:real; begin N0:=(ste(A,N)+ste(B,N)+ste(E,N))/3; R0:=(ste(A,R)+ste(B,R)+ste(E,R))/3; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(E,L2))/3; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(E,N4))/3; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); end;{GB3660} procedure GB3710(A,B,C,D,N,R,S:real; var V0,U0,Q0,I0,M0,F0:real); var N0,R0,S0,L2,N3,K2,R3,N4,N5,N6,N7,R4,R5,P0,Z1,Z2,Z3:real; begin N0:=(ste(A,N)+ste(B,N)+ste(C,N)+ste(D,N))/4; R0:=(ste(A,R)+ste(B,R)+ste(C,R)+ste(D,R))/4; S0:=(ste(A,S)+ste(B,S)+ste(C,S)+ste(D,S))/4; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(C,L2)+ste(D,L2))/4; K2:=2*R; R3:=(ste(A,K2)+ste(B,K2)+ste(C,K2)+ste(D,K2))/4; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(C,N4)+ste(D,N4))/4; N6:=N+S; N7:=(ste(A,N6)+ste(B,N6)+ste(C,N6)+ste(D,N6))/4; R4:=R+S; R5:=(ste(A,R4)+ste(B,R4)+ste(C,R4)+ste(D,R4))/4; V0:=-N0;
244
U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); P0:=(N0*S0-N7)/(N3-N0*N0); Z1:=R0*S0-R5+P0*(N0*R0-N5); Z2:=U0*(N0*S0-N7)+U0*P0*(N0*N0-N3); Z3:=R3-R0*R0+2*U0*(N5-N0*R0); I0:=(Z1+Z2)/(Z3+(N3-N0*N0)*U0*U0); M0:=I0*U0+P0; F0:=-(S0+I0*R0+M0*N0); end;{GB3710} procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); var N0,R0,S0,W0,L2,N3,K2,R3,M2,S3,N4,N5:real; N6,N7,N8,N9,R4,R5,R6,R7,S4,S5,P0:real; Z1,Z2,Z3,Z4,Z5,Z6,Z7,Z0,Z8,Z9,T7:real; T8,T9,G3,G4,G5,G6,G7:real; begin N0:=(ste(A,N)+ste(B,N)+ste(C,N)+ste(D,N)+ste(E,N))/5; R0:=(ste(A,R)+ste(B,R)+ste(C,R)+ste(D,R)+ste(E,R))/5; S0:=(ste(A,S)+ste(B,S)+ste(C,S)+ste(D,S)+ste(E,S))/5; W0:=(ste(A,W)+ste(B,W)+ste(C,W)+ste(D,W)+ste(E,W))/5; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(C,L2)+ste(D,L2)+ste(E,L2))/5; K2:=2*R; R3:=(ste(A,K2)+ste(B,K2)+ste(C,K2)+ste(D,K2)+ste(E,K2))/5; M2:=2*S; S3:=(ste(A,M2)+ste(B,M2)+ste(C,M2)+ste(D,M2)+ste(E,M2))/5; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(C,N4)+ste(D,N4)+ste(E,N4))/5; N6:=N+S; N7:=(ste(A,N6)+ste(B,N6)+ste(C,N6)+ste(D,N6)+ste(E,N6))/5; N8:=N+W; N9:=(ste(A,N8)+ste(B,N8)+ste(C,N8)+ste(D,N8)+ste(E,N8))/5; R4:=R+S; R5:=(ste(A,R4)+ste(B,R4)+ste(C,R4)+ste(D,R4)+ste(E,R4))/5; R6:=R+W; R7:=(ste(A,R6)+ste(B,R6)+ste(C,R6)+ste(D,R6)+ste(E,R6))/5; S4:=S+W; S5:=(ste(A,S4)+ste(B,S4)+ste(C,S4)+ste(D,S4)+ste(E,S4))/5; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); P0:=(N0*S0-N7)/(N3-N0*N0); Z1:=R0*S0-R5+P0*(N0*R0-N5); Z2:=U0*(N0*S0-N7)+U0*P0*(N0*N0-N3); Z3:=R3-R0*R0+2*U0*(N5-N0*R0); I0:=(Z1+Z2)/(Z3+(N3-N0*N0)*U0*U0); M0:=I0*U0+P0; F0:=-(S0+I0*R0+M0*N0); Z4:=R0+U0*N0; Z5:=Z4*N0-N5-U0*N3; Z6:=R3+U0*N5-Z4*R0-Z5*U0; Z7:=Z4*S0+Z5*P0-R5-U0*N7; Z0:=(N0*W0-N9)/(N3-N0*N0); Z8:=Z5*Z0+Z4*W0-R7-U0*N9; Z9:=S3+I0*R5+M0*N7;
245
T7:=R5+I0*R3+M0*N5; T8:=N7+I0*N5+M0*N3; T9:=S0+I0*R0+M0*N0; G3:=S5+I0*R7+M0*N9; G4:=T9*N0-T8; G5:=Z9-T9*S0-G4*P0; G6:=T9*R0-T7+G4*U0; G7:=G4*Z0+T9*W0-G3; G0:=(Z6*G7+Z8*G6)/(Z6*G5-Z7*G6); H0:=(G0*Z7+Z8)/Z6; K0:=G0*P0+H0*U0+Z0; L0:=-(W0+G0*S0+H0*R0+K0*N0); end;{GB3860} procedure GB4150; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; end; end;{GB4150} procedure GB4210; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; L[J]:=ste(F[J],P1)+I1*ste(F[J],O1)+M1*ste(F[J],J1)+F1; end; end;{Gb4210} procedure GB4290; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; L[J]:=ste(F[J],P1)+I1*ste(F[J],O1)+M1*ste(F[J],J1)+F1; M[J]:=ste(F[J],T1)+G1*ste(F[J],P1)+H1*ste(F[J],O1) +K1*ste(F[J],J1)+L1; end; end;{GB4290} procedure GB4170; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; end; end;{GB4170} procedure GB4190; begin for J:=1 to X do begin U[J]:=ste(L[J],J3)+V3; V[J]:=ste(L[J],O3)+U3*ste(L[J],J3)+Q3; end; end;{GB4190}
246
procedure GB4250; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; U[J]:=ste(H[J],P2)+I2*ste(H[J],O2)+M2*ste(H[J],J2)+F2; end; end;{GB4250} procedure GB4340; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; U[J]:=ste(H[J],P2)+I2*ste(H[J],O2)+M2*ste(H[J],J2)+F2; V[J]:=ste(H[J],T2)+G2*ste(H[J],P2)+H2*ste(H[J],O2) +K2*ste(H[J],J2)+L2; end; end;{GB4340} procedure GB4400; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*L[J]; end;{GB4400} procedure GB4420; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*L[J]+B[5]*M[J]; end;{GB4420} procedure GB4450; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]; N5:=B[8]*P[J]*K[J]+B[9]*K[J]*Q[J]; Z[J]:=N3+N4+N5; end; end;{GB4450} procedure GB4490; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; Z[J]:=N3+N4+N5+B[12]*K[J]*U[J]; end; end;{GB4490} procedure GB4530; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J];
247
N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]; Z[J]:=N3+N4+N5+N6+B[15]*K[J]*V[J]; end; end;{GB4530} procedure GB4580; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]+B[12]*K[J]*U[J]; N6:=B[13]*L[J]+B[14]*P[J]*L[J]+B[15]*Q[J]*L[J]; Z[J]:=N3+N4+N5+N6+B[16]*L[J]*U[J]; end; end;{GB4580} procedure GB4630; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]+B[15]*K[J]*V[J]; N7:=B[16]*L[J]+B[17]*P[J]*L[J]+B[18]*Q[J]*L[J]+B[19]*L[J]*U[J]; Z[J]:=N3+N4+N5+N6+N7+B[20]*L[J]*V[J]; end; end;{GB4630} procedure GB4690; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]+B[15]*K[J]*V[J]; N7:=B[16]*L[J]+B[17]*P[J]*L[J]+B[18]*Q[J]*L[J]+B[19]*L[J]*U[J]; R3:=B[20]*L[J]*V[J]+B[21]*M[J]+B[22]*P[J]*M[J]; R4:=B[23]*Q[J]*M[J]+B[24]*U[J]*M[J]+B[25]*M[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R3+R4; end; end;{GB4690} procedure GB4390; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]; end;{GB4390} procedure GB4770; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]+B[12]*P[J]*U[J]; N6:=B[13]*I[J]*P[J]*U[J]+B[14]*V[J]+B[15]*I[J]*V[J]; N7:=B[16]*P[J]*V[J]+B[17]*U[J]*K[J]+B[18]*U[J]*Q[J]; R0:=B[19]*I[J]*P[J]*V[J]+B[20]*I[J]*U[J]*Q[J]; R4:=B[21]*P[J]*U[J]*K[J]+B[22]*K[J]*V[J]+B[23]*Q[J]*V[J];
248
R5:=B[24]*I[J]*Q[J]*V[J]+B[25]*P[J]*K[J]*V[J]; R6:=B[26]*U[J]*K[J]*Q[J]+B[27]*K[J]*Q[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6; end; end;{GB4770} end. unit TPG3_3; Interface uses tpg3_2; var grDriver: Integer; grMode: Integer; procedure PR_MOD; procedure GB4880; procedure GB7000; procedure VVOD31; procedure VVOD32; procedure VVOD33; procedure VVOD41; procedure VVOD42; procedure VVOD51; procedure VVOD52; procedure tablF9; procedure OUT_F_H_L(PR:integer); Implementation procedure VVOD31; begin writeln('Ввод A1 E1 B1 J1 O1'); readln(A1,E1,B1,J1,O1); writeln(F0,'A1=',A1,' E1=',E1,' B1=',B1); writeln(F0,'J1=',J1,' O1=',O1); end;{VVOD31} procedure VVOD32; begin writeln('Ввод A2 E2 B2 J2 O2'); readln(A2,E2,B2,J2,O2); writeln(F0,'A2=',A2,' E2=',E2,' B2=',B2); writeln(F0,'J2=',J2,' O2=',O2); end;{VVOD32} procedure VVOD33; begin writeln('Ввод A3 E3 B3 J3 O3'); readln(A3,E3,B3,J3,O3); writeln(F0,'A3=',A3,' E3=',E3,' B3=',B3); writeln(F0,'J3=',J3,' O3=',O3); end;{VVOD33} procedure VVOD41; begin writeln('Ввод A1 C1 D1 B1 J1 O1 P1'); readln(A1,C1,D1,B1,J1,O1,P1); writeln(F0,'A1=',A1,' C1=',C1,' D1=',D1); writeln(F0,'B1=',B1,' J1=',J1,' O1=',O1); writeln(F0,'P1=',P1); end;{VVOD41} procedure VVOD42; begin writeln('Ввод A2 C2 D2 B2 J2 O2 P2'); readln(A2,C2,D2,B2,J2,O2,P2); writeln(F0,'A2=',A2,' C2=',C2,' D2=',D2); writeln(F0,'B2=',B2,' J2=',J2,' O2=',O2); writeln(F0,'P2=',P2); end;{VVOD42} procedure VVOD51;
249
begin writeln('Ввод A1 C1 E1 D1 B1 J1 O1 P1 T1'); readln(A1,C1,E1,D1,B1,J1,O1,P1,T1); writeln(F0,'A1=',A1,' C1=',C1,' E1=',E1); writeln(F0,'D1=',D1,' B1=',B1,' J1=',J1); writeln(F0,'O1=',O1,' P1=',P1,' T1=',T1); end;{VVOD51} procedure VVOD52; begin writeln('Ввод A2 C2 E2 D2 B2 J2 O2 P2 T2'); readln(A2,C2,E2,D2,B2,J2,O2,P2,T2); writeln(F0,'A2=',A2,' C2=',C2,' E2=',E2); writeln(F0,'D2=',D2,' B2=',B2,' J2=',J2); writeln(F0,'O2=',O2,' P2=',P2,' T2=',T2); end;{VVOD52} procedure PR_MOD; begin case X of 3: begin F[1]:=A1; F[2]:=B1; F[3]:=E1; end; 4: begin F[1]:=A1; F[2]:=B1; F[3]:=C1; F[4]:=D1; end; 5: begin F[1]:=A1; F[2]:=B1; F[3]:=C1; F[4]:=D1; F[5]:=E1; end; 9: begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; end; 12:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=E1; H[5]:=A2; F[6]:=E1; H[6]:=B2; F[7]:=A1; H[7]:=C2; F[8]:=B1; H[8]:=D2; F[9]:=A1; H[9]:=D2; F[10]:=B1; H[10]:=C2; F[11]:=E1; H[11]:=C2; F[12]:=E1; H[12]:=D2; end; 15:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; F[10]:=A1; H[10]:=C2; F[11]:=B1; H[11]:=D2; F[12]:=A1; H[12]:=D2; F[13]:=B1; H[13]:=C2; F[14]:=E1; H[14]:=C2; F[15]:=E1; H[15]:=D2; end; 16:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=C2; F[6]:=B1; H[6]:=C2; F[7]:=A1; H[7]:=D2; F[8]:=B1; H[8]:=D2; F[9]:=C1; H[9]:=A2; F[10]:=C1; H[10]:=C2; F[11]:=C1; H[11]:=D2; F[12]:=C1; H[12]:=B2; F[13]:=D1; H[13]:=A2; F[14]:=D1; H[14]:=C2; F[15]:=D1; H[15]:=D2; F[16]:=D1; H[16]:=B2; end;
250
20:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=A1; H[7]:=C2; F[8]:=B1; H[8]:=D2; F[9]:=A1; H[9]:=D2; F[10]:=B1; H[10]:=C2; F[11]:=C1; H[11]:=A2; F[12]:=C1; H[12]:=C2; F[13]:=C1; H[13]:=E2; F[14]:=C1; H[14]:=D2; F[15]:=C1; H[15]:=B2; F[16]:=D1; H[16]:=A2; F[17]:=D1; H[17]:=C2; F[18]:=D1; H[18]:=E2; F[19]:=D1; H[19]:=D2; F[20]:=D1; H[20]:=B2; end; 25:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; F[10]:=A1; H[10]:=C2; F[11]:=B1; H[11]:=D2; F[12]:=A1; H[12]:=D2; F[13]:=B1; H[13]:=C2; F[14]:=E1; H[14]:=C2; F[15]:=E1; H[15]:=D2; F[16]:=C1; H[16]:=A2; F[17]:=C1; H[17]:=C2; F[18]:=C1; H[18]:=E2; F[19]:=C1; H[19]:=D2; F[20]:=C1; H[20]:=B2; F[21]:=D1; H[21]:=A2; F[22]:=D1; H[22]:=C2; F[23]:=D1; H[23]:=E2; F[24]:=D1; H[24]:=D2; F[25]:=D1; H[25]:=B2; end; 27:begin F[1]:=A1; H[1]:=A2; L[1]:=A3; F[2]:=B1; H[2]:=A2; L[2]:=A3; F[3]:=A1; H[3]:=B2; L[3]:=A3; F[4]:=B1; H[4]:=B2; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; F[9]:=A1; H[9]:=E2; L[9]:=E3; F[10]:=B1; H[10]:=E2; L[10]:=E3; F[11]:=E1; H[11]:=A2; L[11]:=E3; F[12]:=E1; H[12]:=B2; L[12]:=E3; F[13]:=E1; H[13]:=E2; L[13]:=A3; F[14]:=E1; H[14]:=E2; L[14]:=B3; F[15]:=A1; H[15]:=A2; L[15]:=E3; F[16]:=B1; H[16]:=A2; L[16]:=E3; F[17]:=A1; H[17]:=B2; L[17]:=E3; F[18]:=B1; H[18]:=B2; L[18]:=E3; F[19]:=A1; H[19]:=E2; L[19]:=A3; F[20]:=B1; H[20]:=E2; L[20]:=A3; F[21]:=A1; H[21]:=E2; L[21]:=B3; F[22]:=B1; H[22]:=E2; L[22]:=B3; F[23]:=E1; H[23]:=A2; L[23]:=A3; F[24]:=E1; H[24]:=B2; L[24]:=A3; F[25]:=E1; H[25]:=A2; L[25]:=B3; F[26]:=E1; H[26]:=B2; L[26]:=B3; F[27]:=E1; H[27]:=E2; L[27]:=E3; end; end; end; procedure GB4880; begin writeln(F0,'Математическая модель'); if X=3 then writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J),'); if X=9 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J),'); end; if X=27 then begin
251
writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*P(J)*U(J)+',B[13]:10,'*I(J)*P(J)*U(J)+'); writeln(F0,'+',B[14]:10,'*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*P(J)*V(J)+',B[17]:10,'*U(J)*K(J)+'); writeln(F0,'+',B[18]:10,'*U(J)*Q(J)+',B[19]:10,'*I(J)*P(J)*V(J)+'); writeln(F0,'+',B[20]:10,'*I(J)*U(J)*Q(J)+',B[21]:10,'*P(J)*U(J)*K(J)+'); writeln(F0,'+',B[22]:10,'*K(J)*V(J)+',B[23]:10,'*Q(J)*V(J)+'); writeln(F0,'+',B[24]:10,'*I(J)*Q(J)*V(J)+',B[25]:10,'*P(J)*K(J)*V(J)+'); writeln(F0,'+',B[26]:10,'*U(J)*K(J)*Q(J)+',B[27]:10,'*K(J)*Q(J)*V(J),'); end; if (X=3) or (X=27) or (X=9) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=9) or (X=27) then begin writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,','); writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10); end; if X=27 then begin writeln(F0,'U(J)=L(J)^',J3:10,'+',V3:10,','); write(F0,'V(J)=L(J)^',O3:10,'+',O3:10,'+',U3:10,'*L(J)^'); writeln(F0,J3:10,'+',Q3:10); end; if X=4 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*L(J),'); end; if X=5 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*L(J)+',B[5]:10,'*M(J),'); end; if X=12 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J),'); end; if X=15 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+');
252
writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*K(J)*V(J),'); end; if X=16 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*L(J)+'); writeln(F0,'+',B[14]:10,'*P(J)*L(J)+',B[15]:10,'*Q(J)*L(J)+'); writeln(F0,'+',B[16]:10,'*L(J)*U(J),'); end; if X=20 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)+Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*L(J)+',B[17]:10,'*P(J)*L(J)+'); writeln(F0,'+',B[18]:10,'*Q(J)*L(J)+',B[19]:10,'*L(J)*U(J)+'); writeln(F0,'+',B[20]:10,'*L(J)*V(J),'); end; if X=25 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*Q(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*L(J)+',B[17]:10,'*P(J)*L(J)+'); writeln(F0,'+',B[18]:10,'*Q(J)*L(J)+',B[19]:10,'*L(J)*U(J)+'); writeln(F0,'+',B[20]:10,'*L(J)*V(J)+',B[21]:10,'*M(J)+'); writeln(F0,'+',B[22]:10,'*P(J)*M(J)+',B[23]:10,'*Q(J)*M(J)+'); writeln(F0,'+',B[24]:10,'*U(J)*M(J)+',B[25]:10,'*M(J)*V(J),'); end; if (X=4)or(X=5)or(X=12)or(X=15)or(X=16)or (X=20)or(X=20)or(X=25) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=4)or(X=5)or(X=16)or(X=20)or(X=25)then begin writeln(F0,'L(J)=F(J)^',P1:10,'+',I1:10,'*F(J)^',O1:10,'+'); writeln(F0,'+',M1:10,'F(J)^',J1:10,'+',F1:10); end; if (X=5)or(X=25) then begin writeln(F0,'M(J)=F(J)^',T1:10,'+',G1:10,'*F(J)^',P1:10,'+');
253
writeln(F0,'+',H1:10,'*F(J)^',O1:10,'+',K1:10,'*F(J)^',I1:10,'+',L1:10); end; if (X=12)or(X=15) or (X=16) or (X=20) or (X=25) then begin writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,','); writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10,','); writeln(F0,'U(J)=H(J)^',P2:10,'+',I2:10,'*H(J)^',O2:10,'+'); writeln(F0,'+',M2:10,'*H(J)^',J2:10,'+',F2:10); end; if (X=12) or (X=15) or (X=20) or (X=25) then begin writeln(F0,'V(J)=H(J)^',T2:10,'+',G2:10,'*H(J)^',P2:10,'+'); writeln(F0,'+',H2:10,'*H(J)^',O2:10,'+',K2:10,'*H(J)^',J2:10,'+'); writeln(F0,'+',L2:10); end; end;{GB4880} procedure GB7000; label 1; begin repeat writeln('vvod X'); readln(X); writeln('X=',X); writeln(F0,'X=',X); if (X=3)or(X=4)or(X=5) then I0:=61; if (X=9)or(X=12)or(X=15)or(X=16)or(X=20)or(X=25) then I0:=62; if X=27 then I0:=63; if I0=61 then begin case X of 3: I0:=73; 4: I0:=74; 5: I0:=75; end; F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end;{for} case I0 of 73:begin GB4150; GB4390; end; 74:begin
254
GB4210; GB4400; end; 75:begin GB4290; GB4420; end; end;{case} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(73); end;{if} if I0=62 then begin case X of 9: I0:=76; 12:I0:=77; 15:I0:=78; 16:I0:=79; 20:I0:=80; 25:I0:=81; end; F3:=0; F4:=0; H3:=0; H4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); case I0 of 76:begin GB4150; GB4170; GB4450; end; 77:begin GB4150; GB4250; GB4490; end; 78:begin GB4150; GB4340; GB4530; end; 79:begin
255
GB4210; GB4250; GB4580; end; 80:begin GB4210; GB4340; GB4630; end; 81:begin GB4290; GB4340; GB4690; end; end;{case} writeln('Z(',K5,')=',Z[K5]); end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(74); end;{if} if I0=63 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; X:=0; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X,F3,F4,H3,H4,L3,L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); GB4150; GB4170; GB4190; GB4770; end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(75); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); writeln(F0,'Выявление MAX Z(K5) и MIN Z(K5)'); writeln('Ввод I0=90-продолжение'); K8:=0; K8:=Z[1]; readln(I0); for K5:=1 to X do
256
if Z[K5]>=K8 then K8:=Z[K5]; writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln('Graphic. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000} procedure tablF9; begin write(' Значения F7 для 5% уровня'); writeln('значимости'); write('┌───┬──────────────────────────────────'); writeln('───────────────────────┐'); write('│ │ F9 '); writeln(' │'); write('│F8 ├────┬─────┬─────┬─────┬────┬─────┬');
257
writeln('─────┬─────┬─────┬─────┤'); write('│ │ 2 │ 3 │ 4 │ 8 │ 11 │ 14 │'); writeln('15-16│19-20│ 24 │26-30│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 2 │19.0│19.16│19.25│19.37│19.4│19.42│'); writeln('19.43│19.44│19.45│19.46│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 3 │9.55│ 9.28│ 9.12│ 8.84│8.76│ 8.71│'); writeln(' 8.69│ 8.66│ 8.64│ 8.62│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 4 │6.94│ 6.59│ 6.39│ 6.04│5.93│ 5.87│'); writeln(' 5.84│ 5.8 │ 5.77│ 5.74│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 5 │5.79│ 5.41│ 5.19│ 4.82│ 4.7│ 4.64│'); writeln(' 4.6 │ 4.56│ 4.53│ 4.5 │'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 6 │5.14│ 4.76│ 4.53│ 4.15│4.03│ 3.96│'); writeln(' 3.92│ 3.87│ 3.84│ 3.81│'); write('└───┴────┴─────┴─────┴─────┴────┴─────┴'); writeln('─────┴─────┴─────┴─────┘'); end; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────────'); writeln(F0,'─────────────────┐'); write(F0,'│ │ Значение'); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬────'); writeln(F0,'──────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ '); writeln(F0,'L(J) │ Z(J) │'); end; if PR=73 then begin for J:=1 to X do begin
258
writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10); writeln(F0,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; end; end.
259
Программа W6, (три модуля tpg3, _Х=4_, _Х=5_, _Х=20_, Х=3, Х=9, Х=12, Х=15, Х=16, Х=25, Х=27, «система» после «адекватно»)… program tpg3_1; {Математическое моделирование} uses tpg3_3, tpg3_2; label 1,2,3,4,5; procedure VV_DAN; begin case X of 4: begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); end; 16:begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); VVOD42; GB3710(A2,B2,C2,D2,J2,O2,P2,V2,U2,Q2,I2,M2,F2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); end; 20:begin VVOD41; GB3710(A1,B1,C1,D1,J1,O1,P1,V1,U1,Q1,I1,M1,F1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации');
260
writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 5: begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); end; 25:begin VVOD51; GB3860(A1,B1,C1,D1,E1,J1,O1,P1,T1,V1,U1, Q1,I1,M1,F1,G1,H1,K1,L1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln('I1=',I1,' M1=',M1,' F1=',F1); writeln('G1=',G1,' H1=',H1,' K1=',K1); writeln('L1=',L1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'I1=',I1,' M1=',M1,' F1=',F1); writeln(F0,'G1=',G1,' H1=',H1,' K1=',K1); writeln(F0,'L1=',L1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 15:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации');
261
writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD52; GB3860(A2,C2,E2,D2,B2,J2,O2,P2,T2,V2,U2, Q2,I2,M2,F2,G2,H2,K2,L2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln('G2=',G2,' H2=',H2,' K2=',K2); writeln('L2=',L2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'G2=',G2,' H2=',H2,' K2=',K2); writeln(F0,'L2=',L2); end; 3: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); end; 12:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD42; GB3710(A2,C2,D2,B2,J2,O2,P2,V2,U2,Q2,I2,M2,F2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln('I2=',I2,' M2=',M2,' F2=',F2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'I2=',I2,' M2=',M2,' F2=',F2); end; 9: begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); end; 27:begin VVOD31; GB3660(A1,E1,B1,J1,O1,V1,U1,Q1);
262
writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V1=',V1,' U1=',U1,' Q1=',Q1); writeln(F0,'V1=',V1,' U1=',U1,' Q1=',Q1); VVOD32; GB3660(A2,E2,B2,J2,O2,V2,U2,Q2); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V2=',V2,' U2=',U2,' Q2=',Q2); writeln(F0,'V2=',V2,' U2=',U2,' Q2=',Q2); VVOD33; GB3660(A3,E3,B3,J3,O3,V3,U3,Q3); writeln('Коэффициенты ортогонализации'); writeln(F0,'Коэффициенты ортогонализации'); writeln('V3=',V3,' U3=',U3,' Q3=',Q3); writeln(F0,'V3=',V3,' U3=',U3,' Q3=',Q3); end; end;{case} end;{VV_DAN} procedure OUT_Z_B; begin writeln('Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'Расчетные показатели Z(J) до анализа B(J)'); writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ Y(J) │ Z(J) │ Y(J)-Z(J)│'); for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┼──────────┤'); write(F0,'│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln(F0,(Y[J]-Z[J]):10,'│'); write('│ ',J:2,' │',Y[J]:10,'│',Z[J]:10,'│'); writeln((Y[J]-Z[J]):10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; {================================================================ Основная программа =================================================================} begin 1: for J:=1 to 25 do writeln; writeln(' Программа на языке Турбо-Паскаль состоит из трех'); writeln(' файлов tpg3_1,tpg3_2,tpg3_3(w6_1,w6_2,w6_3). Математическое'); writeln('моделирование на основе планирования экспериментов.'); writeln(' Переложение с языка Бейсик программы GGN3.'); writeln(' Разработка Черного А.А.'); writeln(' Autor Chernyy Anatoly Alekseevech'); writeln('Введите имя файла для вывода resultant (без расширения)'); readln(NAME); Assign(F0, (NAME+'.dat')); Rewrite(F0); writeln(F0,'Выполнение программы математического моделирования'); writeln(F0,' tpg3_1(w6_1). (Программа на языке Турбо-Паскаль).'); writeln(F0,' Autor Chernyy Anatoly Alekseevech'); writeln('_X=4_, _X=5_, _X=20_'); writeln('X=3,_X=4_,_X=5_,X=9,X=12,X=15,X=16,_X=20_,X=25,X=27');
263
J:=0;X:=0;F3:=0;F4:=0;H3:=0;H4:=0; L3:=0;L4:=0;K3:=0;K4:=0;K5:=0; K7:=0;K8:=0;K0:=0;X0:=0;Y0:=0;J5:=0; J6:=0;J9:=0;S:=0; writeln('Если X=0, то выход из программы'); write('X=');readln(X); writeln(F0,'X=',X); for J:=1 to X do begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; KK5[J]:=0; KK6[J]:=0; KK7[J]:=0; J7[J]:=0; J8[J]:=0; JJ9[J]:=0; end; VV_DAN; if X=0 then goto 2; PR_MOD; 3:writeln('----------<Меню 1>------------'); writeln('Если I0=6, то переход в начало'); writeln('Если I0=7, то продолжение и'); writeln('ввод величин показателей Y(J)'); write('I0='); readln(I0); if I0=6 then goto 1; writeln('Ввод величин показателей Y(J)'); writeln(F0,'Показатели Y(J)'); for J:=1 to X do begin write('Y(',J,')='); readln(Y[J]); writeln(F0,'Y(',J,')=',Y[J]); end; case X of 3: GB4150; 4: GB4210; 5: GB4290; 9: begin GB4150; GB4170; end; 12:begin GB4150; GB4250; end; 15:begin GB4150; GB4340; end; 16:begin GB4210; GB4250; end; 20:begin GB4210; GB4340; end; 25:begin GB4290; GB4340; end; 27:begin GB4150; GB4170; GB4190; end; end;{case} GB1410;
264
case X of 4: GB2000; 5: begin GB2000; GB2020; end; 9: begin GB1480; end; 12:begin GB1480; GB1600; end; 15:begin GB1480; GB1600; GB1670; end; 16:begin GB1480; GB1600; GB1930; end; 20:begin GB1480; GB1600; GB1670; GB1730; end; 25:begin GB1480; GB1600; GB1670; GB1730; GB1830; end; 27:begin GB1480; GB2040; end; end; writeln('B(J) до анализа'); writeln(F0,'B(J) до анализа'); for J:=1 to X do begin writeln('B(',J,')=',B[J]); writeln(F0,'B(',J,')=',B[J]); end; case X of 3: GB4390; 4: GB4400; 5: GB4420; 9: GB4450; 12:GB4490; 15:GB4530; 16:GB4580; 20:GB4630; 25:GB4690; 27:GB4770; else goto 2; end; OUT_Z_B; 4:writeln('-----------------<Меню 2>--------------------'); writeln('Если I0=3, то ввод результатов опытов'); writeln('на среднем уровне факторов'); writeln('Если I0=4, то ввод дисперсии опытов'); writeln('Если I0=5, то проверка точности и расчеты по модели'); writeln('Если I0=6, то переход в начало программы'); writeln('Если I0=20, то переход в конец программы'); writeln('Если I0=25, то вывод математической модели'); writeln('Если I0=27, то вычисление показателей Z(K5)'); writeln('с использованием циклов'); writeln('Если I0=30, то переход к меню 1'); write('Ввод I0='); readln(I0); if I0=6 then goto 1; if I0=20 then goto 2; if I0=30 then goto 3; if I0=25 then begin GB4880; goto 2; end; if I0=27 then begin GB7000; goto 2; end; if (I0=3)or(I0=4) then begin writeln('Ввод N0-количество опытов на среднем уровне факторов'); readln(N0); writeln(F0,'Количество опытов на среднем уровне факторов N0=',N0); writeln('Ввод F8=N0-1'); readln(F8);
265
writeln(F0,'F8=N0-1=',F8); end; if I0=3 then begin writeln('Ввод G(J)-результаты опытов'); writeln('на среднем уровне факторов'); writeln(F0,'G(J)-результаты опытов'); writeln(F0,'на среднем уровне факторов'); for J:=1 to N0 do begin write('G(',J,')='); readln(G[J]); writeln(F0,'G(',J,')=',G[J]); end; SS:=0; for J:=1 to N0 do SS:=SS+G[J]; S0:=SS/N0; writeln('S0=',S0); SS:=0; for J:=1 to N0 do SS:=SS+(G[J]-S0)*(G[J]-S0); U9:=SS/F8; writeln('Дисперсия опытов U9=',U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if I0=4 then begin writeln('Ввод U9-дисперсия опытов'); readln(U9); writeln(F0,'Дисперсия опытов U9=',U9); end; if not(I0=5) then begin writeln('Расчетные величины T(J)'); writeln(F0,'Расчетные величины T(J)'); for J:=1 to X do begin T[J]:=abs(B[J]/sqrt(U9/O[J])); writeln('T(',J,')=',T[J]); writeln(F0,'T(',J,')=',T[J]); end; writeln('┌──────────────────────────────────┐'); writeln('│ Для уровня значимости 5% │'); writeln('├────┬─────┬─────┬─────┬─────┬─────┤'); writeln('│ F8 │ 2 │ 3 │ 4 │ 5 │ 6 │'); writeln('├────┼─────┼─────┼─────┼─────┼─────┤'); writeln('│ T0 │4,303│3,182│2.776│2,571│2,447│'); writeln('└────┴─────┴─────┴─────┴─────┴─────┘'); writeln('F8=N0-1=',N0,'-1=',F8:1); writeln('Ввод T0-табличного T-критерия'); readln(T0); writeln(F0,'Табличный T-критерий T0=',T0:5:3); writeln('B(J) после анализа'); writeln(F0,'B(J) после анализа'); for J:=1 to X do begin if T[J]
266
end; K9:=0; for J:=1 to X do begin if B[J]=0 then K9:=K9+1; end; writeln('Количество статистически значимых'); writeln('коэффициентов регрессии'); writeln('K9=',K9); writeln('F9=X-1'); F9:=X-1; writeln('F9=',F9); writeln(F0,'Количество статистически значимых'); writeln(F0,'коэффициентов регрессии'); writeln(F0,'K9=',K9); writeln(F0,'F9=X-1'); F9:=X-1; writeln(F0,'F9=',F9); tablF9; writeln('F8=',F8:2,' F9=',F9:2); writeln('Ввод F7-табличного F-критерия'); readln(F7); writeln(F0,'Табличный F-критерий F7=',F7); case X of 3: GB4390; 4: GB4400; 5: GB4420; 9: GB4450; 12:GB4490; 15:GB4530; 16:GB4580; 20:GB4630; 25:GB4690; 27:GB4770; else goto 2; end; writeln('Расчетные величины показателя'); writeln('Z(J) после анализа B(J)'); writeln(F0,'Расчетные величины показателя'); writeln(F0,'Z(J) после анализа B(J)'); for J:=1 to X do begin writeln('Z(',J,')=',Z[J]); writeln(F0,'Z(',J,')=',Z[J]); end; SS:=0; for J:=1 to X do SS:=SS+(Z[J]-Y[J])*(Z[J]-Y[J]); F6:=SS/(F9*U9); writeln('Расчетная величина F-критерия F6=',F6); writeln(F0,'Расчетная величина F-критерия F6=',F6); if F6<=F7 then begin writeln('Адекватно, так как F6<=F7'); writeln(F0,'Адекватно, так как F6<=F7'); end; if F6>F7 then
267
begin writeln('Неадекватно, так как F6>F7'); writeln(F0,'Неадекватно, так как F6>F7'); end; if X=4 then begin writeln(F0,'X=4. System, 1.1 - 1.4, finish 1.4.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','C1=',C1,'Z(3)=',Z[3]); writeln(F0,'1.3.','D1=',D1,'Z(4)=',Z[4]); writeln(F0,'1.4.','B1=',B1,'Z(2)=',Z[2]); end; if X=20 then begin writeln(F0,'X=20. System, 1.1 - 9.5, finish 9.5.'); writeln(F0,'1.1.','A2=',A2,'A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','A2=',A2,'C1=',C1,'Z(11)=',Z[11]); writeln(F0,'1.3.','A2=',A2,'D1=',D1,'Z(16)=',Z[16]); writeln(F0,'1.4.','A2=',A2,'B1=',B1,'Z(2)=',Z[2]); writeln(F0,'2.1.','C2=',C2,'A1=',A1,'Z(7)=',Z[7]); writeln(F0,'2.2.','C2=',C2,'C1=',C1,'Z(12)=',Z[12]); writeln(F0,'2.3.','C2=',C2,'D1=',D1,'Z(17)=',Z[17]); writeln(F0,'2.4.','C2=',C2,'B1=',B1,'Z(10)=',Z[10]); writeln(F0,'3.1.','E2=',E2,'A1=',A1,'Z(5)=',Z[5]); writeln(F0,'3.2.','E2=',E2,'C1=',C1,'Z(13)=',Z[13]); writeln(F0,'3.3.','E2=',E2,'D1=',D1,'Z(18)=',Z[18]); writeln(F0,'3.4.','E2=',E2,'B1=',B1,'Z(6)=',Z[6]); writeln(F0,'4.1.','D2=',D2,'A1=',A1,'Z(9)=',Z[9]); writeln(F0,'4.2.','D2=',D2,'C1=',C1,'Z(14)=',Z[14]); writeln(F0,'4.3.','D2=',D2,'D1=',D1,'Z(19)=',Z[19]); writeln(F0,'4.4.','D2=',D2,'B1=',B1,'Z(8)=',Z[8]); writeln(F0,'5.1.','B2=',B2,'A1=',A1,'Z(3)=',Z[3]); writeln(F0,'5.2.','B2=',B2,'C1=',C1,'Z(15)=',Z[15]); writeln(F0,'5.3.','B2=',B2,'D1=',D1,'Z(20)=',Z[20]); writeln(F0,'5.4.','B2=',B2,'B1=',B1,'Z(4)=',Z[4]); writeln(F0,'6.1.','A1=',A1,'A2=',A2,'Z(1)=',Z[1]); writeln(F0,'6.2.','A1=',A1,'C2=',C2,'Z(7)=',Z[7]); writeln(F0,'6.3.','A1=',A1,'E2=',E2,'Z(5)=',Z[5]); writeln(F0,'6.4.','A1=',A1,'D2=',D2,'Z(9)=',Z[9]); writeln(F0,'6.5.','A1=',A1,'B2=',B2,'Z(3)=',Z[3]); writeln(F0,'7.1.','C1=',C1,'A2=',A2,'Z(11)=',Z[11]); writeln(F0,'7.2.','C1=',C1,'C2=',C2,'Z(12)=',Z[12]); writeln(F0,'7.3.','C1=',C1,'E2=',E2,'Z(13)=',Z[13]); writeln(F0,'7.4.','C1=',C1,'D2=',D2,'Z(14)=',Z[14]); writeln(F0,'7.5.','C1=',C1,'B2=',B2,'Z(15)=',Z[15]); writeln(F0,'8.1.','D1=',D1,'A2=',A2,'Z(16)=',Z[16]); writeln(F0,'8.2.','D1=',D1,'C2=',C2,'Z(17)=',Z[17]); writeln(F0,'8.3.','D1=',D1,'E2=',E2,'Z(18)=',Z[18]); writeln(F0,'8.4.','D1=',D1,'D2=',D2,'Z(19)=',Z[19]); writeln(F0,'8.5.','D1=',D1,'B2=',B2,'Z(20)=',Z[20]); writeln(F0,'9.1.','B1=',B1,'A2=',A2,'Z(2)=',Z[2]); writeln(F0,'9.2.','B1=',B1,'C2=',C2,'Z(10)=',Z[10]); writeln(F0,'9.3.','B1=',B1,'E2=',E2,'Z(6)=',Z[6]); writeln(F0,'9.4.','B1=',B1,'D2=',D2,'Z(8)=',Z[8]); writeln(F0,'9.5.','B1=',B1,'B2=',B2,'Z(4)=',Z[4]); end; if X=5 then
268
begin writeln(F0,'X=5. System, 1.1 - 1.5, finish 1.5.'); writeln(F0,'1.1.','A1=',A1,'Z(1)=',Z[1]); writeln(F0,'1.2.','C1=',C1,'Z(3)=',Z[3]); writeln(F0,'1.3.','E1=',E1,'Z(5)=',Z[5]); writeln(F0,'1.4.','D1=',D1,'Z(4)=',Z[4]); writeln(F0,'1.5.','B1=',B1,'Z(2)=',Z[2]); end; case X of 3: OUT_F_H_L(73); 4: OUT_F_H_L(73); 5: OUT_F_H_L(73); 9: OUT_F_H_L(74); 12:OUT_F_H_L(74); 15:OUT_F_H_L(74); 16:OUT_F_H_L(74); 20:OUT_F_H_L(74); 25:OUT_F_H_L(74); 27:OUT_F_H_L(75); end; end; 5:writeln('----------<Меню 3--------------'); writeln('Если I0=7, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=8, то переход в начало'); writeln('Если I0=17, то математическая модель'); writeln('Если I0=22, то вычисления'); writeln('показателей Z(K5) с использованием'); writeln('циклов и построение графиков'); writeln('Если I0=9, то выход из программы'); writeln('Если I0=25, то переход к меню 1'); writeln('Если I0=27, то переход к меню 2'); write('Ввод I0='); readln(I0); if I0=8 then goto 1; if I0=9 then goto 2; if I0=25 then goto 3; if I0=27 then goto 4; if I0=17 then begin GB4880; goto 2; end; if I0=22 then begin GB7000; goto 2; end; writeln('Проверка точности и расчеты по модели'); writeln('F(S), H(S), L(S) - 1,2,3 факторы'); writeln('где S=X=',X,'-количество опытов по плану'); writeln('расчеты по модели'); writeln(F0,'Проверка точности и расчеты по модели'); writeln(F0,'F(S), H(S), L(S) - 1,2,3 факторы'); writeln(F0,'где S=X=',X,'-количество опытов по плану'); writeln(F0,'расчеты по модели'); if (X=3)or(X=4)or(X=5)then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; writeln('Ввод F(',S,')'); readln(F[S]); case X of 3: begin
269
GB4150; GB4390; end; 4: begin GB4210; GB4400; end; 5: begin GB4290; GB4420; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(73); end;{if} if (X=9)or(X=12)or(X=15)or(X=16)or(X=20)or(X=25)then begin for S:=1 to X do begin F[S]:=0; Z[S]:=0; H[S]:=0; writeln('Ввод F(',S,')',' H(',S,')'); readln(F[S],H[S]); case X of 9: begin GB4150; GB4170; GB4450; end; 12:begin GB4150; GB4250; GB4490; end; 15:begin GB4150; GB4340; GB4530; end; 16:begin GB4210; GB4250; GB4580; end; 20:begin GB4210; GB4340; GB4630; end; 25:begin GB4290; GB4340; GB4690; end; else goto 2; end;{case} writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(74); end;{if} if X=27 then begin for S:=1 to X do begin writeln('Ввод F(',S,')',' H(',S,')',' L(',S,')'); readln(F[S],H[S],L[S]); GB4150; GB4170; GB4190; GB4770; writeln('Z(',S,')=',Z[S]); end;{for} OUT_F_H_L(75); end;{if}
270
2:writeln('----------------<Меню 4------------------'); writeln('Если I0=10, то проверка точности'); writeln('и расчеты по модели'); writeln('Если I0=14, то вычисления '); writeln('показателей Z(K5) с использованием'); writeln('циклов и построение графиков'); writeln('Если I0=35, то переход к меню 1'); writeln('Если I0=18, то переход к меню 2'); writeln('Если I0=19, то переход к меню 3'); writeln('Если I0=50, то переход в начало программы'); writeln('Если I0=44, то выход из программы'); write('Ввод I0='); readln(I0); if I0=11 then goto 1; if I0=18 then goto 4; if (I0=19)or(I0=10) then goto 5; if I0=35 then goto 3; if I0=14 then begin GB7000; goto 2; end; writeln('Конец работы'); close(F0); end.{Конец программы} unit TPG3_2; Interface type artp=array[1..50] of real; var J6,K5,S,J,I0,X,N0,K9,K4,F8,F9:integer; G1,T1,A1,C1,E1,D1,B1,J1,O1,A2,E2,B2,J2,O2,A3:real; H1,K1,L1,F1,M1,I1,P1,E3,B3,J3,O3,V1,U1,Q1,V2,U2,Q2:real; P2,F2,I2,H2,M2,N3,N4,N5,N6,N7,R3,R4,R0,R5,R6:real; S0,J5,S1,V3,U3,Q3,U9,F7,SO,F6:real; J9,L3,SS,L4,H4,H3,F3,F4,C2,D2,T2:real; T0,G2,K2,L2,K7,K8,X0,Y0,K0,K3:real; J7,J8,JJ9,KK5,KK6,KK7,KK8,F,H,V,L,Y,I,K,M,P,Q,U,O,B,Z,G,T:artp; NAME:string[8]; F0: Text; procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); procedure GB3710(A,B,C,D,N,R,S:real; var V0,U0,Q0,I0,M0,F0:real); procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); function ste(Q,A:real):real; procedure GB1410; procedure GB1480; procedure GB1600; procedure GB1670; procedure GB1730; procedure GB1830; procedure GB1930; procedure GB2000; procedure GB2020; procedure GB2040; procedure GB4150; procedure GB4210; procedure GB4290; procedure GB4170; procedure GB4190; procedure GB4250; procedure GB4340; procedure GB4400; procedure GB4420; procedure GB4450; procedure GB4490; procedure GB4530; procedure GB4580; procedure GB4630; procedure GB4690; procedure GB4390; procedure GB4770; Implementation function ste(Q,A:real):real; {Функция возведения в степень} begin
271
if A<0 then begin A:=abs(A); if Q=0 then Q:=1E-5; ste:=1/exp(A*ln(Q)); end else begin if Q=0 then Q:=1E-5; if A=0 then ste:=1 else ste:=exp(A*ln(Q)); end; end;{ste} procedure GB1410; begin SS:=0; O[1]:=0; for J:=1 to X do begin SS:=SS+Y[J]; O[1]:=O[1]+1; end; B[1]:=SS/O[1]; SS:=0; O[2]:=0; for J:=1 to X do begin SS:=SS+I[J]*Y[J]; O[2]:=O[2]+I[J]*I[J]; end; B[2]:=SS/O[2]; SS:=0; O[3]:=0; for J:=1 to X do begin SS:=SS+K[J]*Y[J]; O[3]:=O[3]+K[J]*K[J]; end; B[3]:=SS/O[3]; end;{GB1410} procedure GB1480; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+P[J]*Y[J]; O[4]:=O[4]+P[J]*P[J]; end; B[4]:=SS/O[4]; SS:=0; O[5]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*Y[J]; O[5]:=O[5]+(I[J]*P[J])*(I[J]*P[J]); end; B[5]:=SS/O[5]; SS:=0; O[6]:=0; for J:=1 to X do begin SS:=SS+Q[J]*Y[J]; O[6]:=O[6]+Q[J]*Q[J]; end; B[6]:=SS/O[6]; SS:=0; O[7]:=0; for J:=1 to X do begin
272
SS:=SS+I[J]*Q[J]*Y[J]; O[7]:=O[7]+(I[J]*Q[J])*(I[J]*Q[J]); end; B[7]:=SS/O[7]; SS:=0; O[8]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*Y[J]; O[8]:=O[8]+(P[J]*K[J])*(P[J]*K[J]); end; B[8]:=SS/O[8]; SS:=0; O[9]:=0; for J:=1 to X do begin SS:=SS+K[J]*Q[J]*Y[J]; O[9]:=O[9]+(K[J]*Q[J])*(K[J]*Q[J]); end; B[9]:=SS/O[9]; end;{GB1480} procedure GB1600; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+K[J]*U[J]*Y[J]; O[12]:=O[12]+K[J]*U[J]*K[J]*U[J]; end; B[12]:=SS/O[12]; end;{GB1600} procedure GB1670; begin SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[13]:=O[13]+V[J]*V[J]; end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[14]:=O[14]+I[J]*V[J]*I[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J];
273
O[15]:=O[15]+K[J]*V[J]*K[J]*V[J]; end; B[15]:=SS/O[15]; end;{GB1670} procedure GB1730; begin SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[16]:=O[16]+L[J]*L[J]; end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+P[J]*L[J]*Y[J]; O[17]:=O[17]+(P[J]*L[J])*(P[J]*L[J]); end; B[17]:=SS/O[17]; SS:=0; O[18]:=0; for J:=1 to X do begin SS:=SS+Q[J]*L[J]*Y[J]; O[18]:=O[18]+(Q[J]*L[J])*(Q[J]*L[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+L[J]*U[J]*Y[J]; O[19]:=O[19]+(L[J]*U[J])*(L[J]*U[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+L[J]*V[J]*Y[J]; O[20]:=O[20]+(L[J]*V[J])*(L[J]*V[J]); end; B[20]:=SS/O[20]; end;{GB1730} procedure GB1830; begin SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+M[J]*Y[J]; O[21]:=O[21]+M[J]*M[J]; end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+P[J]*M[J]*Y[J]; O[22]:=O[22]+(P[J]*M[J])*(P[J]*M[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*M[J]*Y[J]; O[23]:=O[23]+(Q[J]*M[J])*(Q[J]*M[J]);
274
end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+U[J]*M[J]*Y[J]; O[24]:=O[24]+(U[J]*M[J])*(U[J]*M[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+M[J]*V[J]*Y[J]; O[25]:=O[25]+(M[J]*V[J])*(M[J]*V[J]); end; B[25]:=SS/O[25]; end;{GB1830} procedure GB1930; begin SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[13]:=O[13]+L[J]*L[J]; end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+P[J]*L[J]*Y[J]; O[14]:=O[14]+(P[J]*L[J])*(P[J]*L[J]); end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+Q[J]*L[J]*Y[J]; O[15]:=O[15]+(Q[J]*L[J])*(Q[J]*L[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+L[J]*U[J]*Y[J]; O[16]:=O[16]+(L[J]*U[J])*(L[J]*U[J]); end; B[16]:=SS/O[16]; end;{GB1930} procedure GB2000; begin SS:=0; O[4]:=0; for J:=1 to X do begin SS:=SS+L[J]*Y[J]; O[4]:=O[4]+L[J]*L[J]; end; B[4]:=SS/O[4]; end;{GB2000} procedure GB2020; begin SS:=0; O[5]:=0; for J:=1 to X do
275
begin SS:=SS+M[J]*Y[J]; O[5]:=O[5]+M[J]*M[J]; end; B[5]:=SS/O[5]; end;{GB2020} procedure GB2040; begin SS:=0; O[10]:=0; for J:=1 to X do begin SS:=SS+U[J]*Y[J]; O[10]:=O[10]+U[J]*U[J]; end; B[10]:=SS/O[10]; SS:=0; O[11]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Y[J]; O[11]:=O[11]+(I[J]*U[J])*(I[J]*U[J]); end; B[11]:=SS/O[11]; SS:=0; O[12]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*Y[J]; O[12]:=O[12]+(P[J]*U[J])*(P[J]*U[J]); end; B[12]:=SS/O[12]; SS:=0; O[13]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*U[J]*Y[J]; O[13]:=O[13]+(I[J]*P[J]*U[J])*(I[J]*P[J]*U[J]); end; B[13]:=SS/O[13]; SS:=0; O[14]:=0; for J:=1 to X do begin SS:=SS+V[J]*Y[J]; O[14]:=O[14]+V[J]*V[J]; end; B[14]:=SS/O[14]; SS:=0; O[15]:=0; for J:=1 to X do begin SS:=SS+I[J]*V[J]*Y[J]; O[15]:=O[15]+(I[J]*V[J])*(I[J]*V[J]); end; B[15]:=SS/O[15]; SS:=0; O[16]:=0; for J:=1 to X do begin SS:=SS+P[J]*V[J]*Y[J]; O[16]:=O[16]+(P[J]*V[J])*(P[J]*V[J]); end; B[16]:=SS/O[16]; SS:=0; O[17]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Y[J]; O[17]:=O[17]+(U[J]*K[J])*(U[J]*K[J]); end; B[17]:=SS/O[17]; SS:=0; O[18]:=0;
276
for J:=1 to X do begin SS:=SS+U[J]*Q[J]*Y[J]; O[18]:=O[18]+(U[J]*Q[J])*(U[J]*Q[J]); end; B[18]:=SS/O[18]; SS:=0; O[19]:=0; for J:=1 to X do begin SS:=SS+I[J]*P[J]*V[J]*Y[J]; O[19]:=O[19]+(I[J]*P[J]*V[J])*(I[J]*P[J]*V[J]); end; B[19]:=SS/O[19]; SS:=0; O[20]:=0; for J:=1 to X do begin SS:=SS+I[J]*U[J]*Q[J]*Y[J]; O[20]:=O[20]+(I[J]*U[J]*Q[J])*(I[J]*U[J]*Q[J]); end; B[20]:=SS/O[20]; SS:=0; O[21]:=0; for J:=1 to X do begin SS:=SS+P[J]*U[J]*K[J]*Y[J]; O[21]:=O[21]+(P[J]*U[J]*K[J])*(P[J]*U[J]*K[J]); end; B[21]:=SS/O[21]; SS:=0; O[22]:=0; for J:=1 to X do begin SS:=SS+K[J]*V[J]*Y[J]; O[22]:=O[22]+(K[J]*V[J])*(K[J]*V[J]); end; B[22]:=SS/O[22]; SS:=0; O[23]:=0; for J:=1 to X do begin SS:=SS+Q[J]*V[J]*Y[J]; O[23]:=O[23]+(Q[J]*V[J])*(Q[J]*V[J]); end; B[23]:=SS/O[23]; SS:=0; O[24]:=0; for J:=1 to X do begin SS:=SS+I[J]*Q[J]*V[J]*Y[J]; O[24]:=O[24]+(I[J]*Q[J]*V[J])*(I[J]*Q[J]*V[J]); end; B[24]:=SS/O[24]; SS:=0; O[25]:=0; for J:=1 to X do begin SS:=SS+P[J]*K[J]*V[J]*Y[J]; O[25]:=O[25]+(P[J]*K[J]*V[J])*(P[J]*K[J]*V[J]); end; B[25]:=SS/O[25]; SS:=0; O[26]:=0; for J:=1 to X do begin SS:=SS+U[J]*K[J]*Q[J]*Y[J]; O[26]:=O[26]+(U[J]*K[J]*Q[J])*(U[J]*K[J]*Q[J]); end; B[26]:=SS/O[26]; SS:=0; O[27]:=0; for J:=1 to X do begin SS:=SS+K[J]*Q[J]*V[J]*Y[J];
277
O[27]:=O[27]+(K[J]*Q[J]*V[J])*(K[J]*Q[J]*V[J]); end; B[27]:=SS/O[27]; end;{GB2040} procedure GB3660(A,B,E,N,R:real; var V0,U0,Q0:real); var L2,N0,R0,N3,N4,N5:real; begin N0:=(ste(A,N)+ste(B,N)+ste(E,N))/3; R0:=(ste(A,R)+ste(B,R)+ste(E,R))/3; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(E,L2))/3; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(E,N4))/3; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); end;{GB3660} procedure GB3710(A,B,C,D,N,R,S:real; var V0,U0,Q0,I0,M0,F0:real); var N0,R0,S0,L2,N3,K2,R3,N4,N5,N6,N7,R4,R5,P0,Z1,Z2,Z3:real; begin N0:=(ste(A,N)+ste(B,N)+ste(C,N)+ste(D,N))/4; R0:=(ste(A,R)+ste(B,R)+ste(C,R)+ste(D,R))/4; S0:=(ste(A,S)+ste(B,S)+ste(C,S)+ste(D,S))/4; L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(C,L2)+ste(D,L2))/4; K2:=2*R; R3:=(ste(A,K2)+ste(B,K2)+ste(C,K2)+ste(D,K2))/4; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(C,N4)+ste(D,N4))/4; N6:=N+S; N7:=(ste(A,N6)+ste(B,N6)+ste(C,N6)+ste(D,N6))/4; R4:=R+S; R5:=(ste(A,R4)+ste(B,R4)+ste(C,R4)+ste(D,R4))/4; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); P0:=(N0*S0-N7)/(N3-N0*N0); Z1:=R0*S0-R5+P0*(N0*R0-N5); Z2:=U0*(N0*S0-N7)+U0*P0*(N0*N0-N3); Z3:=R3-R0*R0+2*U0*(N5-N0*R0); I0:=(Z1+Z2)/(Z3+(N3-N0*N0)*U0*U0); M0:=I0*U0+P0; F0:=-(S0+I0*R0+M0*N0); end;{GB3710} procedure GB3860(A,B,C,D,E,N,R,S,W:real; var V0,U0,Q0,I0,M0,F0,G0,H0,K0,L0:real); var N0,R0,S0,W0,L2,N3,K2,R3,M2,S3,N4,N5:real; N6,N7,N8,N9,R4,R5,R6,R7,S4,S5,P0:real; Z1,Z2,Z3,Z4,Z5,Z6,Z7,Z0,Z8,Z9,T7:real; T8,T9,G3,G4,G5,G6,G7:real; begin N0:=(ste(A,N)+ste(B,N)+ste(C,N)+ste(D,N)+ste(E,N))/5; R0:=(ste(A,R)+ste(B,R)+ste(C,R)+ste(D,R)+ste(E,R))/5; S0:=(ste(A,S)+ste(B,S)+ste(C,S)+ste(D,S)+ste(E,S))/5; W0:=(ste(A,W)+ste(B,W)+ste(C,W)+ste(D,W)+ste(E,W))/5;
278
L2:=2*N; N3:=(ste(A,L2)+ste(B,L2)+ste(C,L2)+ste(D,L2)+ste(E,L2))/5; K2:=2*R; R3:=(ste(A,K2)+ste(B,K2)+ste(C,K2)+ste(D,K2)+ste(E,K2))/5; M2:=2*S; S3:=(ste(A,M2)+ste(B,M2)+ste(C,M2)+ste(D,M2)+ste(E,M2))/5; N4:=N+R; N5:=(ste(A,N4)+ste(B,N4)+ste(C,N4)+ste(D,N4)+ste(E,N4))/5; N6:=N+S; N7:=(ste(A,N6)+ste(B,N6)+ste(C,N6)+ste(D,N6)+ste(E,N6))/5; N8:=N+W; N9:=(ste(A,N8)+ste(B,N8)+ste(C,N8)+ste(D,N8)+ste(E,N8))/5; R4:=R+S; R5:=(ste(A,R4)+ste(B,R4)+ste(C,R4)+ste(D,R4)+ste(E,R4))/5; R6:=R+W; R7:=(ste(A,R6)+ste(B,R6)+ste(C,R6)+ste(D,R6)+ste(E,R6))/5; S4:=S+W; S5:=(ste(A,S4)+ste(B,S4)+ste(C,S4)+ste(D,S4)+ste(E,S4))/5; V0:=-N0; U0:=(N0*R0-N5)/(N3-N0*N0); Q0:=-(R0+U0*N0); P0:=(N0*S0-N7)/(N3-N0*N0); Z1:=R0*S0-R5+P0*(N0*R0-N5); Z2:=U0*(N0*S0-N7)+U0*P0*(N0*N0-N3); Z3:=R3-R0*R0+2*U0*(N5-N0*R0); I0:=(Z1+Z2)/(Z3+(N3-N0*N0)*U0*U0); M0:=I0*U0+P0; F0:=-(S0+I0*R0+M0*N0); Z4:=R0+U0*N0; Z5:=Z4*N0-N5-U0*N3; Z6:=R3+U0*N5-Z4*R0-Z5*U0; Z7:=Z4*S0+Z5*P0-R5-U0*N7; Z0:=(N0*W0-N9)/(N3-N0*N0); Z8:=Z5*Z0+Z4*W0-R7-U0*N9; Z9:=S3+I0*R5+M0*N7; T7:=R5+I0*R3+M0*N5; T8:=N7+I0*N5+M0*N3; T9:=S0+I0*R0+M0*N0; G3:=S5+I0*R7+M0*N9; G4:=T9*N0-T8; G5:=Z9-T9*S0-G4*P0; G6:=T9*R0-T7+G4*U0; G7:=G4*Z0+T9*W0-G3; G0:=(Z6*G7+Z8*G6)/(Z6*G5-Z7*G6); H0:=(G0*Z7+Z8)/Z6; K0:=G0*P0+H0*U0+Z0; L0:=-(W0+G0*S0+H0*R0+K0*N0); end;{GB3860} procedure GB4150; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; end; end;{GB4150} procedure GB4210;
279
begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; L[J]:=ste(F[J],P1)+I1*ste(F[J],O1)+M1*ste(F[J],J1)+F1; end; end;{Gb4210} procedure GB4290; begin for J:=1 to X do begin I[J]:=ste(F[J],J1)+V1; K[J]:=ste(F[J],O1)+U1*ste(F[J],J1)+Q1; L[J]:=ste(F[J],P1)+I1*ste(F[J],O1)+M1*ste(F[J],J1)+F1; M[J]:=ste(F[J],T1)+G1*ste(F[J],P1)+H1*ste(F[J],O1) +K1*ste(F[J],J1)+L1; end; end;{GB4290} procedure GB4170; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; end; end;{GB4170} procedure GB4190; begin for J:=1 to X do begin U[J]:=ste(L[J],J3)+V3; V[J]:=ste(L[J],O3)+U3*ste(L[J],J3)+Q3; end; end;{GB4190} procedure GB4250; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; U[J]:=ste(H[J],P2)+I2*ste(H[J],O2)+M2*ste(H[J],J2)+F2; end; end;{GB4250} procedure GB4340; begin for J:=1 to X do begin P[J]:=ste(H[J],J2)+V2; Q[J]:=ste(H[J],O2)+U2*ste(H[J],J2)+Q2; U[J]:=ste(H[J],P2)+I2*ste(H[J],O2)+M2*ste(H[J],J2)+F2; V[J]:=ste(H[J],T2)+G2*ste(H[J],P2)+H2*ste(H[J],O2) +K2*ste(H[J],J2)+L2; end; end;{GB4340} procedure GB4400; begin
280
for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*L[J]; end;{GB4400} procedure GB4420; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*L[J]+B[5]*M[J]; end;{GB4420} procedure GB4450; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]; N5:=B[8]*P[J]*K[J]+B[9]*K[J]*Q[J]; Z[J]:=N3+N4+N5; end; end;{GB4450} procedure GB4490; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; Z[J]:=N3+N4+N5+B[12]*K[J]*U[J]; end; end;{GB4490} procedure GB4530; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]; Z[J]:=N3+N4+N5+N6+B[15]*K[J]*V[J]; end; end;{GB4530} procedure GB4580; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]+B[12]*K[J]*U[J]; N6:=B[13]*L[J]+B[14]*P[J]*L[J]+B[15]*Q[J]*L[J]; Z[J]:=N3+N4+N5+N6+B[16]*L[J]*U[J]; end; end;{GB4580} procedure GB4630; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J];
281
N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]+B[15]*K[J]*V[J]; N7:=B[16]*L[J]+B[17]*P[J]*L[J]+B[18]*Q[J]*L[J]+B[19]*L[J]*U[J]; Z[J]:=N3+N4+N5+N6+N7+B[20]*L[J]*V[J]; end; end;{GB4630} procedure GB4690; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]; N6:=B[12]*K[J]*U[J]+B[13]*V[J]+B[14]*I[J]*V[J]+B[15]*K[J]*V[J]; N7:=B[16]*L[J]+B[17]*P[J]*L[J]+B[18]*Q[J]*L[J]+B[19]*L[J]*U[J]; R3:=B[20]*L[J]*V[J]+B[21]*M[J]+B[22]*P[J]*M[J]; R4:=B[23]*Q[J]*M[J]+B[24]*U[J]*M[J]+B[25]*M[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R3+R4; end; end;{GB4690} procedure GB4390; begin for J:=1 to X do Z[J]:=B[1]+B[2]*I[J]+B[3]*K[J]; end;{GB4390} procedure GB4770; begin for J:=1 to X do begin N3:=B[1]+B[2]*I[J]+B[3]*K[J]+B[4]*P[J]; N4:=B[5]*I[J]*P[J]+B[6]*Q[J]+B[7]*I[J]*Q[J]+B[8]*P[J]*K[J]; N5:=B[9]*K[J]*Q[J]+B[10]*U[J]+B[11]*I[J]*U[J]+B[12]*P[J]*U[J]; N6:=B[13]*I[J]*P[J]*U[J]+B[14]*V[J]+B[15]*I[J]*V[J]; N7:=B[16]*P[J]*V[J]+B[17]*U[J]*K[J]+B[18]*U[J]*Q[J]; R0:=B[19]*I[J]*P[J]*V[J]+B[20]*I[J]*U[J]*Q[J]; R4:=B[21]*P[J]*U[J]*K[J]+B[22]*K[J]*V[J]+B[23]*Q[J]*V[J]; R5:=B[24]*I[J]*Q[J]*V[J]+B[25]*P[J]*K[J]*V[J]; R6:=B[26]*U[J]*K[J]*Q[J]+B[27]*K[J]*Q[J]*V[J]; Z[J]:=N3+N4+N5+N6+N7+R0+R4+R5+R6; end; end;{GB4770} end. unit TPG3_3; Interface uses tpg3_2; var grDriver: Integer; grMode: Integer; procedure PR_MOD; procedure GB4880; procedure GB7000; procedure VVOD31; procedure VVOD32; procedure VVOD33; procedure VVOD41; procedure VVOD42; procedure VVOD51; procedure VVOD52; procedure tablF9; procedure OUT_F_H_L(PR:integer); Implementation procedure VVOD31; begin writeln('Ввод A1 E1 B1 J1 O1');
282
readln(A1,E1,B1,J1,O1); writeln(F0,'A1=',A1,' E1=',E1,' B1=',B1); writeln(F0,'J1=',J1,' O1=',O1); end;{VVOD31} procedure VVOD32; begin writeln('Ввод A2 E2 B2 J2 O2'); readln(A2,E2,B2,J2,O2); writeln(F0,'A2=',A2,' E2=',E2,' B2=',B2); writeln(F0,'J2=',J2,' O2=',O2); end;{VVOD32} procedure VVOD33; begin writeln('Ввод A3 E3 B3 J3 O3'); readln(A3,E3,B3,J3,O3); writeln(F0,'A3=',A3,' E3=',E3,' B3=',B3); writeln(F0,'J3=',J3,' O3=',O3); end;{VVOD33} procedure VVOD41; begin writeln('Ввод A1 C1 D1 B1 J1 O1 P1'); readln(A1,C1,D1,B1,J1,O1,P1); writeln(F0,'A1=',A1,' C1=',C1,' D1=',D1); writeln(F0,'B1=',B1,' J1=',J1,' O1=',O1); writeln(F0,'P1=',P1); end;{VVOD41} procedure VVOD42; begin writeln('Ввод A2 C2 D2 B2 J2 O2 P2'); readln(A2,C2,D2,B2,J2,O2,P2); writeln(F0,'A2=',A2,' C2=',C2,' D2=',D2); writeln(F0,'B2=',B2,' J2=',J2,' O2=',O2); writeln(F0,'P2=',P2); end;{VVOD42} procedure VVOD51; begin writeln('Ввод A1 C1 E1 D1 B1 J1 O1 P1 T1'); readln(A1,C1,E1,D1,B1,J1,O1,P1,T1); writeln(F0,'A1=',A1,' C1=',C1,' E1=',E1); writeln(F0,'D1=',D1,' B1=',B1,' J1=',J1); writeln(F0,'O1=',O1,' P1=',P1,' T1=',T1); end;{VVOD51} procedure VVOD52; begin writeln('Ввод A2 C2 E2 D2 B2 J2 O2 P2 T2'); readln(A2,C2,E2,D2,B2,J2,O2,P2,T2); writeln(F0,'A2=',A2,' C2=',C2,' E2=',E2); writeln(F0,'D2=',D2,' B2=',B2,' J2=',J2); writeln(F0,'O2=',O2,' P2=',P2,' T2=',T2); end;{VVOD52} procedure PR_MOD; begin case X of 3: begin F[1]:=A1; F[2]:=B1; F[3]:=E1; end; 4: begin
283
F[1]:=A1; F[2]:=B1; F[3]:=C1; F[4]:=D1; end; 5: begin F[1]:=A1; F[2]:=B1; F[3]:=C1; F[4]:=D1; F[5]:=E1; end; 9: begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; end; 12:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=E1; H[5]:=A2; F[6]:=E1; H[6]:=B2; F[7]:=A1; H[7]:=C2; F[8]:=B1; H[8]:=D2; F[9]:=A1; H[9]:=D2; F[10]:=B1; H[10]:=C2; F[11]:=E1; H[11]:=C2; F[12]:=E1; H[12]:=D2; end; 15:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; F[10]:=A1; H[10]:=C2; F[11]:=B1; H[11]:=D2; F[12]:=A1; H[12]:=D2; F[13]:=B1; H[13]:=C2; F[14]:=E1; H[14]:=C2; F[15]:=E1; H[15]:=D2; end; 16:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=C2; F[6]:=B1; H[6]:=C2; F[7]:=A1; H[7]:=D2; F[8]:=B1; H[8]:=D2; F[9]:=C1; H[9]:=A2; F[10]:=C1; H[10]:=C2; F[11]:=C1; H[11]:=D2; F[12]:=C1; H[12]:=B2; F[13]:=D1; H[13]:=A2; F[14]:=D1; H[14]:=C2; F[15]:=D1; H[15]:=D2; F[16]:=D1; H[16]:=B2; end; 20:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=A1; H[7]:=C2; F[8]:=B1; H[8]:=D2; F[9]:=A1; H[9]:=D2; F[10]:=B1; H[10]:=C2; F[11]:=C1; H[11]:=A2; F[12]:=C1; H[12]:=C2; F[13]:=C1; H[13]:=E2; F[14]:=C1; H[14]:=D2; F[15]:=C1; H[15]:=B2; F[16]:=D1; H[16]:=A2; F[17]:=D1; H[17]:=C2; F[18]:=D1; H[18]:=E2; F[19]:=D1; H[19]:=D2; F[20]:=D1; H[20]:=B2; end; 25:begin F[1]:=A1; H[1]:=A2; F[2]:=B1; H[2]:=A2; F[3]:=A1; H[3]:=B2; F[4]:=B1; H[4]:=B2; F[5]:=A1; H[5]:=E2; F[6]:=B1; H[6]:=E2; F[7]:=E1; H[7]:=A2; F[8]:=E1; H[8]:=B2; F[9]:=E1; H[9]:=E2; F[10]:=A1; H[10]:=C2; F[11]:=B1; H[11]:=D2; F[12]:=A1; H[12]:=D2; F[13]:=B1; H[13]:=C2; F[14]:=E1; H[14]:=C2; F[15]:=E1; H[15]:=D2; F[16]:=C1; H[16]:=A2; F[17]:=C1; H[17]:=C2; F[18]:=C1; H[18]:=E2; F[19]:=C1; H[19]:=D2; F[20]:=C1; H[20]:=B2; F[21]:=D1; H[21]:=A2; F[22]:=D1; H[22]:=C2; F[23]:=D1; H[23]:=E2; F[24]:=D1; H[24]:=D2; F[25]:=D1; H[25]:=B2; end;
284
27:begin F[1]:=A1; H[1]:=A2; L[1]:=A3; F[2]:=B1; H[2]:=A2; L[2]:=A3; F[3]:=A1; H[3]:=B2; L[3]:=A3; F[4]:=B1; H[4]:=B2; L[4]:=A3; F[5]:=A1; H[5]:=A2; L[5]:=B3; F[6]:=B1; H[6]:=A2; L[6]:=B3; F[7]:=A1; H[7]:=B2; L[7]:=B3; F[8]:=B1; H[8]:=B2; L[8]:=B3; F[9]:=A1; H[9]:=E2; L[9]:=E3; F[10]:=B1; H[10]:=E2; L[10]:=E3; F[11]:=E1; H[11]:=A2; L[11]:=E3; F[12]:=E1; H[12]:=B2; L[12]:=E3; F[13]:=E1; H[13]:=E2; L[13]:=A3; F[14]:=E1; H[14]:=E2; L[14]:=B3; F[15]:=A1; H[15]:=A2; L[15]:=E3; F[16]:=B1; H[16]:=A2; L[16]:=E3; F[17]:=A1; H[17]:=B2; L[17]:=E3; F[18]:=B1; H[18]:=B2; L[18]:=E3; F[19]:=A1; H[19]:=E2; L[19]:=A3; F[20]:=B1; H[20]:=E2; L[20]:=A3; F[21]:=A1; H[21]:=E2; L[21]:=B3; F[22]:=B1; H[22]:=E2; L[22]:=B3; F[23]:=E1; H[23]:=A2; L[23]:=A3; F[24]:=E1; H[24]:=B2; L[24]:=A3; F[25]:=E1; H[25]:=A2; L[25]:=B3; F[26]:=E1; H[26]:=B2; L[26]:=B3; F[27]:=E1; H[27]:=E2; L[27]:=E3; end; end; end; procedure GB4880; begin writeln(F0,'Математическая модель'); if X=3 then writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J),'); if X=9 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J),'); end; if X=27 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*P(J)*U(J)+',B[13]:10,'*I(J)*P(J)*U(J)+'); writeln(F0,'+',B[14]:10,'*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*P(J)*V(J)+',B[17]:10,'*U(J)*K(J)+'); writeln(F0,'+',B[18]:10,'*U(J)*Q(J)+',B[19]:10,'*I(J)*P(J)*V(J)+'); writeln(F0,'+',B[20]:10,'*I(J)*U(J)*Q(J)+',B[21]:10,'*P(J)*U(J)*K(J)+'); writeln(F0,'+',B[22]:10,'*K(J)*V(J)+',B[23]:10,'*Q(J)*V(J)+'); writeln(F0,'+',B[24]:10,'*I(J)*Q(J)*V(J)+',B[25]:10,'*P(J)*K(J)*V(J)+'); writeln(F0,'+',B[26]:10,'*U(J)*K(J)*Q(J)+',B[27]:10,'*K(J)*Q(J)*V(J),'); end; if (X=3) or (X=27) or (X=9) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=9) or (X=27) then begin
285
writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,','); writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10); end; if X=27 then begin writeln(F0,'U(J)=L(J)^',J3:10,'+',V3:10,','); write(F0,'V(J)=L(J)^',O3:10,'+',O3:10,'+',U3:10,'*L(J)^'); writeln(F0,J3:10,'+',Q3:10); end; if X=4 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*L(J),'); end; if X=5 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*L(J)+',B[5]:10,'*M(J),'); end; if X=12 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J),'); end; if X=15 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*K(J)*V(J),'); end; if X=16 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*L(J)+'); writeln(F0,'+',B[14]:10,'*P(J)*L(J)+',B[15]:10,'*Q(J)*L(J)+'); writeln(F0,'+',B[16]:10,'*L(J)*U(J),'); end; if X=20 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)+Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*K(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+');
286
writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*L(J)+',B[17]:10,'*P(J)*L(J)+'); writeln(F0,'+',B[18]:10,'*Q(J)*L(J)+',B[19]:10,'*L(J)*U(J)+'); writeln(F0,'+',B[20]:10,'*L(J)*V(J),'); end; if X=25 then begin writeln(F0,'Z(J)=',B[1]:10,'+',B[2]:10,'*I(J)+',B[3]:10,'*K(J)+'); writeln(F0,'+',B[4]:10,'*P(J)+',B[5]:10,'*I(J)*P(J)+'); writeln(F0,'+',B[6]:10,'*Q(J)+',B[7]:10,'*I(J)*Q(J)+'); writeln(F0,'+',B[8]:10,'*P(J)*Q(J)+',B[9]:10,'*K(J)*Q(J)+'); writeln(F0,'+',B[10]:10,'*U(J)+',B[11]:10,'*I(J)*U(J)+'); writeln(F0,'+',B[12]:10,'*K(J)*U(J)+',B[13]:10,'*V(J)+'); writeln(F0,'+',B[14]:10,'*I(J)*V(J)+',B[15]:10,'*I(J)*V(J)+'); writeln(F0,'+',B[16]:10,'*L(J)+',B[17]:10,'*P(J)*L(J)+'); writeln(F0,'+',B[18]:10,'*Q(J)*L(J)+',B[19]:10,'*L(J)*U(J)+'); writeln(F0,'+',B[20]:10,'*L(J)*V(J)+',B[21]:10,'*M(J)+'); writeln(F0,'+',B[22]:10,'*P(J)*M(J)+',B[23]:10,'*Q(J)*M(J)+'); writeln(F0,'+',B[24]:10,'*U(J)*M(J)+',B[25]:10,'*M(J)*V(J),'); end; if (X=4)or(X=5)or(X=12)or(X=15)or(X=16)or (X=20)or(X=20)or(X=25) then begin writeln(F0,'ГДЕ'); writeln(F0,'I(J)=F(J)^',J1:10,'+',V1:10,','); writeln(F0,'K(J)=F(J)^',O1:10,'+',U1:10,'*F(J)^',J1:10,'+',Q1:10); end; if (X=4)or(X=5)or(X=16)or(X=20)or(X=25)then begin writeln(F0,'L(J)=F(J)^',P1:10,'+',I1:10,'*F(J)^',O1:10,'+'); writeln(F0,'+',M1:10,'F(J)^',J1:10,'+',F1:10); end; if (X=5)or(X=25) then begin writeln(F0,'M(J)=F(J)^',T1:10,'+',G1:10,'*F(J)^',P1:10,'+'); writeln(F0,'+',H1:10,'*F(J)^',O1:10,'+',K1:10,'*F(J)^',I1:10,'+',L1:10); end; if (X=12)or(X=15) or (X=16) or (X=20) or (X=25) then begin writeln(F0,'P(J)=H(J)^',J2:10,'+',V2:10,','); writeln(F0,'Q(J)=H(J)^',O2:10,'+',U2:10,'*H(J)^',J2:10,'+',Q2:10,','); writeln(F0,'U(J)=H(J)^',P2:10,'+',I2:10,'*H(J)^',O2:10,'+'); writeln(F0,'+',M2:10,'*H(J)^',J2:10,'+',F2:10); end; if (X=12) or (X=15) or (X=20) or (X=25) then begin writeln(F0,'V(J)=H(J)^',T2:10,'+',G2:10,'*H(J)^',P2:10,'+'); writeln(F0,'+',H2:10,'*H(J)^',O2:10,'+',K2:10,'*H(J)^',J2:10,'+'); writeln(F0,'+',L2:10); end; end;{GB4880} procedure GB7000; label 1; begin repeat writeln('vvod X'); readln(X);
287
writeln('X=',X); writeln(F0,'X=',X); if (X=3)or(X=4)or(X=5) then I0:=61; if (X=9)or(X=12)or(X=15)or(X=16)or(X=20)or(X=25) then I0:=62; if X=27 then I0:=63; if I0=61 then begin case X of 3: I0:=73; 4: I0:=74; 5: I0:=75; end; F3:=0; F4:=0; K5:=0; writeln('Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения фактора'); writeln('X-количество значений фактора'); writeln('Ввод принятых величин X F3 F4'); readln(X,F3,F4); writeln(F0,'F4-шаг приращения фактора'); writeln(F0,'X-количество значений фактора'); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); end;{for} case I0 of 73:begin GB4150; GB4390; end; 74:begin GB4210; GB4400; end; 75:begin GB4290; GB4420; end; end;{case} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(73); end;{if} if I0=62 then begin case X of 9: I0:=76; 12:I0:=77; 15:I0:=78; 16:I0:=79; 20:I0:=80; 25:I0:=81; end; F3:=0; F4:=0; H3:=0; H4:=0; K5:=0;
288
writeln('Фактор F(1)=F3+F4'); writeln(F0,'Фактор F(1)=F3+F4'); for J:=1 to X do begin F[J]:=0; H[J]:=0; Z[J]:=0; end; writeln('F4-шаг приращения 1-го фактора'); writeln('Фактор H(1)=H3+H4'); writeln('H4-шаг приращения 2-го фактора'); writeln('X-количество значений 1,2-го фактора'); writeln('Ввод принятых величин X F3 F4 H3 H4'); writeln(F0,'F4-шаг приращения 1-го фактора'); writeln(F0,'Фактор H(1)=H3+H4'); writeln(F0,'H4-шаг приращения 2-го фактора'); writeln(F0,'X-количество значений 1,2-го фактора'); readln(X,F3,F4,H3,H4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); case I0 of 76:begin GB4150; GB4170; GB4450; end; 77:begin GB4150; GB4250; GB4490; end; 78:begin GB4150; GB4340; GB4530; end; 79:begin GB4210; GB4250; GB4580; end; 80:begin GB4210; GB4340; GB4630; end; 81:begin GB4290; GB4340; GB4690; end; end;{case} writeln('Z(',K5,')=',Z[K5]); end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(74); end;{if} if I0=63 then begin K5:=0; F3:=0; F4:=0; H3:=0; H4:=0; L3:=0; L4:=0; writeln('Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); writeln(F0,'Факторы F(1)=F3+F4, H(1)=H3+H4, L(1)=L3+L4'); for J:=1 to X do
289
begin F[J]:=0; H[J]:=0; L[J]:=0; Z[J]:=0; end; X:=0; writeln('F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln('X-количество значений 1,2,3-го фактора'); writeln(F0,'F4,H4,L4-шаг приращения 1,2,3-го фактора'); writeln(F0,'X-количество значений 1,2,3-го фактора'); writeln('Ввод принятых величин'); writeln('X,F3,F4,H3,H4,L3,L4'); readln(X,F3,F4,H3,H4,L3,L4); writeln(F0,'X=',X,' F3=',F3,' F4=',F4); writeln(F0,'H3=',H3,' H4=',H4); writeln(F0,'L3=',L3,' L4=',L4); for K5:=1 to X do begin F[K5]:=F3+K5*F4; writeln('F(',K5,')=',F[K5]); H[K5]:=H3+K5*H4; writeln('H(',K5,')=',H[K5]); L[K5]:=L3+K5*L4; writeln('L(',K5,')=',L[K5]); GB4150; GB4170; GB4190; GB4770; end;{for} for K5:=1 to X do writeln('Z(',K5,')=',Z[K5]); OUT_F_H_L(75); end;{if} writeln('Выявление MAX Z(K5) и MIN Z(K5)'); writeln(F0,'Выявление MAX Z(K5) и MIN Z(K5)'); writeln('Ввод I0=90-продолжение'); K8:=0; K8:=Z[1]; readln(I0); for K5:=1 to X do if Z[K5]>=K8 then K8:=Z[K5]; writeln('MAX Z(K5)=',K8); writeln(F0,'MAX Z(K5)=',K8); for K5:=1 to X do if Z[K5]=K8 then begin writeln('MAX Z(',K5,')=',Z[K5]); writeln(F0,'MAX Z(',K5,')=',Z[K5]); end; K7:=0; K7:=Z[1]; for K5:=1 to X do if Z[K5]<=K7 then K7:=Z[K5]; writeln('MIN Z(K5)=',K7); writeln(F0,'MIN Z(K5)=',K7); for K5:=1 to X do if Z[K5]=K7 then begin writeln('MIN Z(',K5,')=',Z[K5]); writeln(F0,'MIN Z(',K5,')=',Z[K5]); end; writeln('MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln('K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))');
290
writeln(F0,'MIN Z(K5)=K7, MAX Z(K5)=K8'); writeln(F0,'K6(K5)=(Z(K5)+abs(K7))/(abs(K7)+abs(K8))'); for K5:=1 to X do begin KK6[K5]:=(Z[K5]+abs(K7))/(abs(K7)+abs(K8)); writeln('K6(',K5,')=',KK6[K5]); writeln(F0,'K6(',K5,')=',KK6[K5]); end; J5:=0; J5:=abs(K7)/(abs(K7)+abs(K8)); writeln('J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln('J5=',J5); writeln(F0,'J5:=abs(K7)/(abs(K7)+abs(K8))'); writeln(F0,'J5=',J5); writeln(F0,'Построение графика. Excel'); writeln(F0,'Зависимость KK6(K5) от фактора'); writeln(F0,'KK6(K5)-относительная величина показателя'); writeln(F0,'K5-номер величины фактора и показателя'); writeln('if I0=92 then GB7000'); writeln('if I0=94 then goto 1'); write('I0='); readln(I0); if I0=92 then GB7000; if I0=94 then goto 1; 1: until I0=94; end;{GB7000} procedure tablF9; begin write(' Значения F7 для 5% уровня'); writeln('значимости'); write('┌───┬──────────────────────────────────'); writeln('───────────────────────┐'); write('│ │ F9 '); writeln(' │'); write('│F8 ├────┬─────┬─────┬─────┬────┬─────┬'); writeln('─────┬─────┬─────┬─────┤'); write('│ │ 2 │ 3 │ 4 │ 8 │ 11 │ 14 │'); writeln('15-16│19-20│ 24 │26-30│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 2 │19.0│19.16│19.25│19.37│19.4│19.42│'); writeln('19.43│19.44│19.45│19.46│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 3 │9.55│ 9.28│ 9.12│ 8.84│8.76│ 8.71│'); writeln(' 8.69│ 8.66│ 8.64│ 8.62│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 4 │6.94│ 6.59│ 6.39│ 6.04│5.93│ 5.87│'); writeln(' 5.84│ 5.8 │ 5.77│ 5.74│'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 5 │5.79│ 5.41│ 5.19│ 4.82│ 4.7│ 4.64│'); writeln(' 4.6 │ 4.56│ 4.53│ 4.5 │'); write('├───┼────┼─────┼─────┼─────┼────┼─────┼'); writeln('─────┼─────┼─────┼─────┤'); write('│ 6 │5.14│ 4.76│ 4.53│ 4.15│4.03│ 3.96│');
291
writeln(' 3.92│ 3.87│ 3.84│ 3.81│'); write('└───┴────┴─────┴─────┴─────┴────┴─────┴'); writeln('─────┴─────┴─────┴─────┘'); end; procedure OUT_F_H_L(PR:integer); begin if PR=73 then begin writeln(F0,'┌────┬─────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ Z(J) │'); end; if PR=74 then begin writeln(F0,'┌────┬────────────────────────────────┐'); writeln(F0,'│ │ Значение │'); writeln(F0,'│ J ├──────────┬──────────┬──────────┤'); writeln(F0,'│ │ F(J) │ H(J) │ Z(J) │'); end; if PR=75 then begin write(F0,'┌────┬──────────────────────────'); writeln(F0,'─────────────────┐'); write(F0,'│ │ Значение'); writeln(F0,' │'); write(F0,'│ J ├──────────┬──────────┬────'); writeln(F0,'──────┬──────────┤'); write(F0,'│ │ F(J) │ H(J) │ '); writeln(F0,'L(J) │ Z(J) │'); end; if PR=73 then begin for J:=1 to X do begin writeln(F0,'├────┼──────────┼──────────┤'); writeln(F0,'│ ',J:2,' │',F[J]:10,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┘'); end; if PR=74 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┤'); write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10); writeln(F0,'│',Z[J]:10,'│'); end; writeln(F0,'└────┴──────────┴──────────┴──────────┘'); end; if PR=75 then begin for J:=1 to X do begin write(F0,'├────┼──────────┼──────────┼'); writeln(F0,'──────────┼──────────┤');
292
write(F0,'│ ',J:2,' │',F[J]:10,'│',H[J]:10,'│'); writeln(F0,L[J]:10,'│',Z[J]:10,'│'); end; write(F0,'└────┴──────────┴──────────┴'); writeln(F0,'──────────┴──────────┘'); end; end; end.
293
КОНТРОЛЬНЫЕ ВОПРОСЫ 1. Какие права являются авторскими правами и какие права принадлежат автору произведения? 2. На что распространяются исключительные права? 3. Кто признается автором произведения? 4. Кто может быть соавтором произведения? 5. Что является объектом авторского права? 6. Как защищаются авторские права на программы для ЭВМ? 7. Предусмотрена ли государственная регистрация программ для ЭВМ и баз данных? 8. Что такое право авторства, право автора на имя, право на неприкосновенность произведения, как охраняется авторство, имя автора и неприкосновенность произведения? 9. Почему автору принадлежит право на обнародование произведения? 10. Может ли автор отказаться от ранее принятого решения об обнародовании произведения? 11. Как выполняется исключительное право на произведение? 12. Что входит в знак охраны авторского права? 13. В каких случаях распространяется оригинал или экземпляры опубликованного произведения без согласия правообладателя и свободное воспроизведение произведения в личных целях? 14. Как используются произведения в информационных, научных, учебных целях? 15. Допускается ли без согласия автора свободное использование произведения путем репродуцирования? 16. В каких случаях можно свободно использовать произведение без согласия автора? 17. Что допускается вносить в программу для ЭВМ и базу данных? 18. Какой предусмотрен срок действия исключительного права на произведение? 19. Когда переходит произведение в общественное достояние? 20. Как заключается лицензионный договор о предоставлении права использования произведения? 21. Каковые особые условия издательского лицензионного договора? 22. Как заключается договор авторского заказа, каков срок исполнения договора авторского заказа, каков срок исполнения договора авторского заказа? 23. Каковы особенности отчуждения оригинала произведения и исключительного права на произведение? 24. Что подразумевается под правом доступа, правом следования?
294
25. Какие права предусмотрены на служебные произведения, на программы для ЭВМ и базы данных, созданные по заказу или при выполнении работ по договору, на произведения, созданные по государственному или муниципальному контракту? 26. Какие предусмотрены технические защиты авторских прав? 27. Как информируется авторское право? 28. Какова ответственность за нарушение исключительного права на произведение? 29. Как обеспечивается иск по делам о нарушении авторских прав? 30. В чем различие авторских и смежных прав?
295
Л И Т Е Р А Т У РА 1. Гражданский кодекс Российской Федерации №230-ФЗ от 18.12.2006. Принят: Государственной Думой 24 ноября 2006 года. Одобрен Советом Федерации 8 декабря 2006 года. Опубликовано: 22 декабря 2006г. Вступил в силу с 1 января 2008 г. 2. Интеллектуальная собственность/Под общ.ред.д.т.н.,проф. Н.М. Коршунова.-М.: Норма, 2005.-304с. 3. Черный А.А. Математическое моделирование при планировании экспериментов на двух уровнях факторов: учебное пособие / А.А. Черный. – Пенза: Информационно-издательский центр ПГУ, 2006. – 36 с. 4. Черный А.А. Математическое моделирование при планировании экспериментов на трех уровнях факторов: учебное пособие / А.А. Черный. – Пенза: Информационно-издательский центр ПГУ, 2006. – 80 с. 5. Черный А.А. Математическое моделирование при планировании экспериментов на четырех уровнях факторов: учебное пособие / А.А. Черный. – Пенза: Информационно-издательский центр ПГУ, 2006. – 92 с. 6. Черный А.А. Математическое моделирование при планировании экспериментов на пяти уровнях факторов: учебное пособие / А.А. Черный. – Пенза: Информационно-издательский центр ПГУ, 2006. – 40 с. 7. Черный А.А. Математическое моделирование при планировании экспериментов на трех, четырех, пяти уровнях факторов и при неодинаковом количестве уровней первого и второго факторов: учебное пособие / А.А. Черный. – Пенза: Информационноиздательский центр ПГУ, 2006. – 56 с. 8. Черный А.А. Применение математического моделирования для прогнозирования свойств сплавов // Математическое и компьютерное моделирование естественнонаучных и социальных проблем: сборник статей I Международной научно-технической конференции молодых специалистов, аспирантов и студентов. – Пенза: Пензенский государственный университет, АНОО «Приволжский Дом знаний», 2007. – С. 135-139. 9. Черный А.А. Математическое моделирование в литейном производстве: учебное пособие / А.А. Черный. – Пенза: Информационно-издательский центр ПГУ, 2007. – 192 с.
296
10. Черный А.А. Компьютерные программы математического моделирования и расчетов по математическим моделям: Учеб. пособие. – Пенза: Изд-во Пенз. гос. ун-та, 2006. – 197 с. 11. Черный А.А. Системный анализ результатов расчетов по математическим моделям: учебное пособие/А.А. Черный.-Пенза: Пензенский государственный университет, 2007.-143с. 12. Черный А.А. Математическое моделирование применительно к литейному производству: Учебн. пособие. - Пенза: Пенз. гос. ун-та, 1998. – 121 с. 13. Фигурнов В.Э. IBM PC для использования. Краткий курс. – М.: ИНФРА-М, 1997. – 480 с. 14. Программирование на языке Бейсик для персональных ЭВМ/ З.П. Вострикова, О.Ю. Вострикова, С.С. Туева. – М.: Машиностроение, 1993. – 352 с. 15. Технология конструкционных материалов: Учебник для машиностроительных специальностей вузов/ А.М. Дальский, И.А. Артунова, Т.М. Барсуков идр.; Под общей редакцией А.М. Дальского. 2-е изд., переработанное и дополненное – М.: Машиностроение, 1985. – 448 с. 16. Черный А.А. Практика планирования экспериментов и математического моделирования процессов. – Саратов: Изд-во Сарат.ун-та, 1984. – 103 с. 17. Каймин В.А. Информатика: Учебник. – 2-е изд., перераб. и доп. – М.: ИНФРА _ М, 2002. – 272 с. – (Серия « Высшее образование). 18. Фридланд А.Я., Ханамирова Л.С., Фридланд И.А. Информатика. Толковый словарь основных терминов. Издание 2-е. – М., «Издательство ПРИОР», 1998. – 240 с. 19. Маковский В.А., Похлебаев В.И. Бейсик. – М.: Издательство стандартов, 1992. – 75 с. – (Я работаю на персональном компьютере; Вып.3). 20. Маковский В.А., Похлебаев В.И. Первые встречи с IBM PC. – М.: Издательство стандартов, 1992. – 48 с. – (Я работаю на персональном компьютере; Вып.1). 21. Маковский В.А., Похлебаев В.И. IBM PC на моем рабочем месте. – М.: Издательство стандартов, 1992. – 46 с. – (Я работаю на персональном компьютере; Вып.5). 22. Маковский В.А., Похлебаев В.И. Текстовой процессор ЛЕКСИКОН. – М.: Издательство стандартов, 1992. – 31 с. – (Я работаю на персональном компьютере; Вып.4).
297
23. Фаронов В.В. Турбо Паскаль (в 3-х книгах. Книга 1. Основы Турбо Паскаля. – М.: Учебно-инженерный центр « МВТУ-ФЕСТО ДИДАКТИК», 1992. – 304 с. 24. Ступин Ю.В., Семененко В.А. Основы программирования: Учебное пособие для ПТУ. – М.: Машиностроение, 1986. – 240 с. 25. Курдюмов А.В., Тен Э.Б. Расчет оптимального состава шихты на ЭВМ. – М.: «Металлургия», 1984. – 73 с. 26. Михайлов В.Ю., Степаннинко В.М. Современный Бейсик для IBM PC. Среда, язык, программирование. – М.: Изд-во МАИ, 1993. –288 с. 27.Черный А.А. Математическое моделирование при планировании экспериментов на двух уровнях факторов: учебное пособие / А.А. Черный. – Пенза: Информационно-издательский центр ПГУ, 2006. – 36 с. 28.Маковский В.А., Похлебаев В.И. Бейсик. – М.: Издательство стандартов, 1992. – 75 с. (Я работаю на персональном компьютере; Вып. 3). 29.Фаронов В.В. Турбо-Паскаль (в 3-х книгах). Книга 1. Основы ТурбоПаскаля. – М.: Учебно-инженерный центр «МВТУ-ФЕСТО ДИДАКТИК», 1992. – 304 с. 30.Черный А.А. Компьютерные дополненные программы математического моделирования и расчетов по математическим моделям: учебное пособие/А.А. Черный.-Пенза: Информационноиздательский центр ПензГУ, 2008.-356с.
298
СОДЕРЖАНИЕ ВВЕДЕНИЕ ……………………………………………………………..… 3 ОСНОВНЫЕ ПОЛОЖЕНИЯ АВТОРСКИХ ПРАВ…………………… .. 4 ПРИМЕРЫ ИНТЕЛЛЕКТУАЛЬНЫХ РАЗРАБОТОК АВТОРА……….26 ПРОГРАММЫ МАТЕМАТИЧЕСКОГО МОДЕЛИРОВАНИЯ НА ЯЗЫКЕ ТУРБО ПАСКАЛЬ……………………………………………29 Программа LV1(два модуля tpgl3, 1-й вариант, _Х=2_, _Х=4_, _Х=8_, Х=16, «система» после «адекватно»)……………………………30 Программа TNV1(два модуля tpgl3, 2-ой вариант _Х=2_, _Х=4_, _Х=8_, Х=16, «система» до «модели»)……………………………………50 Программа TNV3(два модуля tpgl3, 1-я часть, Х=2, Х=4, Х=8, _Х=16_, Х=32, «система» после «адекватно», 1.1-11.2)…tpgl3………….76 Программа TNV4(два модуля tpgl3, 2-я часть, Х=2, Х=4, Х=8, _Х=16_, Х=32, «система» после «адекватно», 12.1-22.2)……………….101 Программа TNV5(два модуля tpgl3, 3-я часть, Х=2, Х=4, Х=8, _Х=16_, Х=32, «система» после «адекватно», 23.1-32.2)………………..126 Программа NW3(три модуля tpg3, 1-я часть, _Х=3_, _Х=9_, _Х=27_, «система» после «адекватно», 1.1-18.3)……….151 Программа NW0(три модуля tpg3, 2-я часть, _Х=3_, _Х=9_, _Х=27_, Х=4, Х=5, Х=12, Х=15, Х=16, Х=20, Х=25, «система» после «адекватно», 19.1-27.3)………………………….172 Программа NW5(три модуля tpg3, _Х=5_, _Х=25_, «система» после «адекватно»)……………………………………………..206 Программа NW6 (три модуля tpg3, _Х=3_, _Х=4_, _Х=5_, _Х=12_, _Х=15_, Х=9, Х=16, Х=20, Х=25, Х=27 «система» после «адекватно»)…………………………………………………………………226 Программа W6, (три модуля tpg3, _Х=4_, _Х=5_, _Х=20_, Х=3, Х=9, Х=12, Х=15, Х=16, Х=25, Х=27, «система» после «адекватно»)…………………………………………………………260 КОНТРОЛЬНЫЕ ВОПРОСЫ …………………………………………… 294 ЛИТЕРАТУРА ……………………………………………………………..296
299
Анатолий Алексеевич Черный АВТОРСКИЕ ПРАВА НА ПРОИЗВЕДЕНИЯ НАУКИ, ПРОГРАММЫ ДЛЯ ЭВМ Учебное пособие
________________________________________________________ Издательство Пензенского государственного университета. 440026, Пенза, Красная, 40
300