Клиентская часть технологической среды для разработки больших экономических моделей: компоненты поддержки работы эксперта-экономиста при формировании и отладке (в расчетном режиме) структурного текста модели
Требования, предъявляемые к системе экономического планирования. Архитектура Borland Database Engine (IDAPI) – ядро доступа к данным. Выбор платформы проектирования и еe обоснование. Структура экономической модели. Инфологическая модель базы данных.
Рубрика | Программирование, компьютеры и кибернетика |
Вид | дипломная работа |
Язык | русский |
Дата добавления | 10.09.2010 |
Размер файла | 1,4 M |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Хотя это и новый подход в программировании, но и до появления RAD-средств делались попытки облегчить труд программиста, сделать этот труд более продуктивным, повысив этим быстродействие и удобство создания приложений. Первоначально появились интегрированные среды разработки - IDE (Integrated Development Environment), объединяющие компилятор, специальный текстовый редактор, ориентированный на работы с текстами на целевом языке программирования и средства отладки - трассировщик--дебаггер и другие. По сравнению с предыдущими средствами программирования это был большой шаг вперед, но затем появились CASE-средства, которые позволяли максимально визуализировать процесс создания программы, но пользоваться ими было чересчур неудобно из-за их негибкости. В большинстве случаев написать достаточно сложную программу было очень трудно. Сейчас эти средства используются там, где подход достаточно однообразен - например при написании средств работы с базами данных.
Средства же быстрой разработки приложений (в дальнейшем - RAD-средства), взяв все лучшее из интегрированных сред разработки и CASE систем, объединили мощь и гибкость работы с исходными текстами с удобством создания графического интерфейса пользователя - GUI (Graphic User Interface). К сожалению, большинство RAD-средств не позволяют визуализировать логику самой программы, но и те методы, которые заложены в современные RAD-средства, позволяют поднять производительность разработки программ в 2-3 раза.
Первой вариантом RAD-средств можно назвать продукт фирмы Microsoft - Visual Basic, появившийся в начале девяностых годов. Но пик популярности подобных средств наступил совсем недавно - сразу несколько ведущих фирм по производству средств создания приложений анонсировали новые версии своих продуктов, которые уже могут по праву называться RAD-средствами. Среди них можно назвать Microsoft Visual C++, Microsoft Visual Java, Power Builder (PowerSoft), Optima++ (PowerSoft), Borland Delphi, Borland C++ Builder и много других. В данной главе основной акцент будет делаться на систему Borland Delphi 3, поскольку именно эта среда использовалась при разработке программы в рамках данного дипломного проекта. Соответственно, большее внимание будет уделяться и диалекту языка Pascal - Object Pascal, который используется в качестве языка программирования в среде Delphi.
2.2 Особенности RAD-средств
Две основных черты RAD-средств - это визуальная компонентность и многократное использование кода. Каждая из этих черт предназначена для повышения производительности программирования. Рассмотрим их подробнее.
2.2.1 Визуальная компонентность
Данный подход является логическим развитием объектно-ориентированного программирования (ООП). Каждый компонент имеет свои события (events), методы (methods) и свойства (properties). Методы и события пришли из объектно-ориентированного программирования, а свойства являются привилегией компонентного подхода. Свойства позволяют изменить состояние компонента, причем как динамически - во время работы программы, так и статически - визуально во время разработки. Естественно, что компоненты имеет все те особенности, что и объекты в объектно-ориентированном программировании - наследование, полиморфизм и инкапсуляция. Таким образом, описание типичного компонента выглядит следующим образом:
TBitBtn = class(TButton)
private
FCanvas: TCanvas;
FGlyph: Pointer;
FStyle: TButtonStyle;
FKind: TBitBtnKind;
FLayout: TButtonLayout;
FSpacing: Integer;
FMargin: Integer;
IsFocused: Boolean;
FModifiedGlyph: Boolean;
procedure DrawItem(const DrawItemStruct: TDrawItemStruct);
procedure SetGlyph(Value: TBitmap);
function GetGlyph: TBitmap;
function GetNumGlyphs: TNumGlyphs;
procedure SetNumGlyphs(Value: TNumGlyphs);
procedure GlyphChanged(Sender: TObject);
function IsCustom: Boolean;
function IsCustomCaption: Boolean;
procedure SetStyle(Value: TButtonStyle);
procedure SetKind(Value: TBitBtnKind);
function GetKind: TBitBtnKind;
procedure SetLayout(Value: TButtonLayout);
procedure SetSpacing(Value: Integer);
procedure SetMargin(Value: Integer);
procedure CNMeasureItem(var Message: TWMMeasureItem); message CN_MEASUREITEM;
procedure CNDrawItem(var Message: TWMDrawItem); message CN_DRAWITEM;
procedure CMFontChanged(var Message: TMessage); message CM_FONTCHANGED;
procedure CMEnabledChanged(var Message: TMessage); message CM_ENABLEDCHANGED;
procedure WMLButtonDblClk(var Message: TWMLButtonDblClk);
message WM_LBUTTONDBLCLK;
protected
procedure CreateHandle; override;
procedure CreateParams(var Params: TCreateParams); override;
function GetPalette: HPALETTE; override;
procedure SetButtonStyle(ADefault: Boolean); override;
public
constructor Create(AOwner: TComponent); override;
destructor Destroy; override;
procedure Click; override;
published
property Cancel stored IsCustom;
property Caption stored IsCustomCaption;
property Default stored IsCustom;
property Enabled;
property Glyph: TBitmap read GetGlyph write SetGlyph stored IsCustom;
property Kind: TBitBtnKind read GetKind write SetKind default bkCustom;
property Layout: TButtonLayout read FLayout write SetLayout default blGlyphLeft;
property Margin: Integer read FMargin write SetMargin default -1;
property ModalResult stored IsCustom;
property NumGlyphs: TNumGlyphs read GetNumGlyphs write SetNumGlyphs stored IsCustom default 1;
property ParentShowHint;
property ShowHint;
property Style: TButtonStyle read FStyle write SetStyle default bsAutoDetect;
property Spacing: Integer read FSpacing write SetSpacing default 4;
property TabOrder;
property TabStop;
property Visible;
property OnEnter;
property OnExit;
end;
В данном примере описан стандартный компонент TBitBtn, наследующий от стандартного класса Tbutton - стандартная кнопка, используемая повсеместно в Windows. Он имеет четыре секции в описании - private, protected, published и public. Данные секции регламентируют доступ к методам, полям и свойствам, находящимся в них для других компонент и для программ пользователя.
2.2.2 Многократное использование кода
Термин «многократное использование кода» (code reuse) говорит сам за себя. Данная технология подразумевает возможность написания таких участков программ, которые затем с небольшими изменениями (или совсем без изменений) могут быть использованы в другой программе. Нельзя сказать, что такой подход является привилегией средств быстрой разработки приложений - еще раньше программисты поняли преимущества возможности выделения универсальных и часто используемых подпрограмм в отдельные библиотеки (модули). Таким образом появлялись библиотеки подпрограмм для различных языков программирования, работающие с графикой, базами данных, реализующие многие математические функции и прочие универсальные задачи. Но именно в RAD-средствах технология многократного использования кода приобрела законченный и целостный вид - существует широкий набор стандартных компонентов, которые могут использоваться во многих программах различного типа, а при необходимости получения какого-либо компонента с отличными от стандартных возможностями, его написание облегчается из-за механизма наследования от уже существующих компонентов их свойств и методов.
Сложность данного подхода в изменении идеологии программирования - разработчик должен изначально ориентироваться на создания кода, который затем можно будет многократно использовать. Особенно актуальна эта проблема для групп разработчиков. В этом случае необходимо мыслить глобально, с учетом требований всех членов группы и перспективы дальнейших разработок.
Кроме описанных особенностей средств быстрой разработки приложений, следует отметить наличие определенного инструментария, который призван помогать разработчику при создании стандартных элементов приложений. Эти средства автоматизируют рутинную работу при генерации например графического интерфейса. В различных средах они носят различное наименование - expert и master в средах фирмы Borland и wizard в средах, разработанных фирмой Microsoft.
2.3 Создание программ в среде Delphi
Благодаря всем вышеописанным преимуществам технологии быстрого проектирования приложений, создание программ в среде Delphi является удобным и необременительным делом. Для генерации программы первоначально необходимо создать файл проекта, имя которого будет совпадать с именем будущей программы. Причем Delphi сама сделает каркас программы - пользователю необходимо только выбрать соответствующий пункт в диалоговом окне New, которое показано на рис.6
Рис.6. Окно выбора объекта создания
Таким образом, выбрав тип создаваемой программы, программист получит готовый шаблон, который затем необходимо будет заполнить содержанием.
Каждое окно в Delphi называется формой. На форме располагаются различные визуальные и не визуальные компоненты. Весь набор компонент, доступных в системе, хранится в файле complib.dcl или в файле с другим именем и отображается в специальном окне среды Delphi, называемом «палитрой компонент» (component palette).
Рис.7. Палитра компонентов
Палитра разбивается на страницы, группирующие компоненты по каким-либо общим признакам.
Рис.8. Пример создания экранной формы
Например, на одной странице помещаются компоненты работы с данными, на другой - сетевые и т.д. Гибкость среды Delphi позволяет настраивать палитру по своему усмотрению - объединять, разбивать страницы, переносит компоненты с одной страницы на другую и т.п. Для того, чтобы поместить компонент на форму, необходимо нажать на его изображении на палитре компонент кнопку «мыши», затем переместить указатель «мыши» на нужное место и там отпустить. Это процесс приведет к тому, что у класса формы появится поле типа этого компонента. Собрав на одну форму несколько компонентов, можно получит сколь угодно сложные диалоговые окна с полями ввода, мемо-полями и прочими компонентами. Простой пример создаваемого окна (в режиме разработки) показан на рис.8.
На рис.8 показана разрабатываемая форма с несколькими визуальными компонентами. Хотя количество визуальных компонент на форме практически не ограничено, здравый смысл подсказывает, что перегружать форму ими не целесообразно, поскольку пользоваться программой с большим количеством кнопок, полей ввода и т.д. будет трудно из-за информационной перенасыщенности. Кроме того, рекомендуется каждый визуальный компонент снабжать строкой описания, чтобы пользователь мог догадаться, что же от него требуется.
Кроме визуальных, существуют также невизуальные компоненты. Поместив такой компонент на форму и запустив программу, мы ничего не увидим. Но некоторые компоненты во время работы себя отображают, правда для этого необходимо вызвать их методы. К таким компонентам относится всевозможные диалоговые компоненты, например OpenDialog, который является стандартным окном для открытия файла. Другие невизуальные компоненты внешне никак себя не проявляют, например компонент DataSet.
Свойства каждого компонента и формы в целом, а также события, на которые они откликаются, отображаются в окне инспектора объектов (object inspector). Инспектор объектов имеет две страницы - страницу со свойствами и страницу с событиями. Общий вид обеих страниц указан на рис.9
Рис.9. Инспектор объектов
При редактировании свойства в инспекторе объектов учитывается тип этого свойства. Например, если свойство логического типа, то возможен будет выбор только лишь между значениями True и False. Для более сложных свойств, например, для списков строк, существуют свои редакторы свойств. Например, компонент ComboBox с рис.8 имеет свойство Items типа списка строк - TStrings. В этом случае нажатие на кнопку с многоточием, расположенную рядом с именем свойства, приведет к активизации редактора списка строк. Его вид показан на рис.10
Для нестандартных свойств, описанных программистом, существует возможность создания своего редактора свойств методами Delphi.
Рис.10. Редактор списка строк
Кроме задания значений свойств, инспектор помогает задавать реакцию на всевозможные события, которые могут происходить в программе - перемещение указателя «мыши», нажатие и отпускание клавиш клавиатуры и т.п. На соответствующей страничке инспектора есть список множества стандартных для компонента (или формы) событий. Каждому событию соответствует своя процедура обработки этого события. Причем одна процедура может обрабатывать несколько событий. Все это указывается с помощью инспектора событий.
Замечу, что визуальными средствами среды Delphi построить законченное приложение практически невозможно. Такими средствами можно только облегчить создание программы. Всю логику придется писать старым, испытанным методом - для каждой процедуры обработки событий вручную вписывать код.
В этом параграфе была рассмотрена упрощенная схема разработки программы в среде Delphi. Но кроме создания исходного текста необходимо помнить и об отладке программ.
2.4 Отладка программ
Рис11. Инспектор классов.
Процесс отладки программ в средах быстрой разработки приложений также упрощен по сравнению с обычной схемой. После компиляции программы можно посмотреть структуру ее классов с помощью окна Browse, представленного на рис.11
Это окно дает много полезной информации об иерархии классов и их структуре в данной программе. Кроме того, можно посмотреть значения любых полей и свойств во время работы программы, если программа запущена из-под среды. Для этого используется отладчик. Функционально отладчик ничем не отличается от стандартного отладчика, который используется во всех программных продуктах фирмы Borland. Он имеет режим пошагового выполнения с заходом или без захода в подпрограммы, возможность установки точек останова, окно просмотра значений переменных и другие функции.
Гибкость, простота и удобство работы со средствами быстрой разработки приложений, объединенные с мощью языковой поддержки, позволяют сделать вывод о перспективности таких средств в будущем. Уже сейчас практически каждый месяц в средствах массовой информации появляются сообщения о появлении новых RAD-средств, и в дальнейшем такая тенденция должна сохраниться.
Глава 3
Организационно - экономическая часть
“Расчёт затрат на разработку программы”
3. Расчёт затрат на разработку программы
3.1 Введение
Цель составления любых программ состоит в получении определенных результатов в процессе эксплуатации и оценивается эффективностью программного средства. Уточним применяемое далее понятие эффективности процесса разработки программного средства. Выбор адекватных показателей эффективности программных средств зависит от их назначения, области применения, а также от ряда характеристик программ, проявляющихся при их применении. Поэтому, для выбора технических решений могут использоваться различные критерии. Целесообразно подразумевать под эффективностью процесса разработки минимум затрат на разработку программ при заданной экономической эффективности применения и качества программных средств. Минимизация затрат на обеспечение жизненного цикла комплекта программ (далее КП) в некоторой степени эквивалентны максимизации разности эффекта и затрат, если предположить, что экономический эффект от применения программ зафиксирован и стабилен. Затраты в жизненном цикле ПО определяются не только этапом разработки, но и этапами эксплуатации и сопровождения, причем затраты на этих этапах могут значительно превосходить затраты на этапе проектирования и разработки и характеризуются своими особыми закономерностями. Неодновременность групп затрат не учитывается, и предполагается, что абсолютная величина и влияние затрат со временем не изменяется. Обычно, критерии качества изделий используются в совокупности, с разных сторон отражающей основные характеристики функционирования объекта. Тем не менее во многих случаях доминирует экономический эффект, который наиболее прост, и обобщенно принято описывать суммарным доходом Э от использования изделия в течении его жизненного цикла продолжительностью Тж. В первом приближении это разность между полной идеальной экономической эффективностью программы Эо и суммарными потерями и затратами K , снижающими предельный доход за весь жизненный цикл:
Э = Эо - K
В качестве идеальной эффективности Эо рассматривается совокупный доход, который можно получить от использования программ за весь жизненный цикл, если бы они не требовали затрат на создание, производство и эксплуатацию, а также функционировали бы на реализующих ЭВМ без потерь и искажений.
Предполагается, что при любых затратах на разработку всегда достигается заданная идеальная эффективность последующего применения ПО в процессе его эксплуатации и необходимые показатели качества функционирования. Это предположение позволяет в дальнейшем исключить из анализа эффективность применения программных средств Эо и сосредоточить внимание на эффективности процесса их разработки. Дополнительным основанием такого допущения может служить то, что многие виды программ невозможно или очень трудно характеризовать доходом от их функционирования. Тогда исследования эффективности процесса создания ПО можно проводить, минимизируя затраты K в предположении, что обеспечены заданные функциональные характеристики программ.
Снижение эффективности Э на величину K происходит прежде всего вследствие затрат на разработку, производство, сопровождение и эксплуатацию программ, а так же вследствие различных сбоев программ и оборудования.
В соответствии с этапами жизненного цикла ПО основные затраты K, снижающие идеальную эффективность за цикл жизни Тж, можно представить следующими составляющими:
затраты на создание КП и обеспечение решения заданных задач (в том числе на документацию, технологическое обеспечение, аппаратную оснащенность разработки) - Kр;
затраты на эксплуатацию программных и аппаратных средств ЭВМ, реализующих КП - Sэ;
затраты на сопровождение КП, включающие затраты на хранение и контроль его состояния, проведение модификации и разработку документации, исправление ошибок и рекламу и т.д. - Kс;
накладные расходы Kн;
в результате совокупную реальную эффективность функционирования ПО за весь жизненный цикл длительностью Тж можно представить в виде:
Э = Эо - Kр - Sэ - Kс - Kн
3.2 Составляющие затрат на разработку программ Kр
Разработка программ является областью с малой материало- и энергоемкостью, и основные затраты связаны с непосредственным или овеществленным трудом специалистов различных категорий.
Наибольшее значение в составе Ср при разработке сложных комплексов программ ( КП ) имеют следующие составляющие затрат:
на непосредственное проектирование, программирование, отладку и испытания программ в соответствии с требованиями пользователя или заказчика - K1р;
на изготовление опытного образца КП как продукции производственно-технического назначения - K2р;
на разработку, подготовку и применение технологии программных средств автоматизации разработки программ - K3р;
на технологические и реализующие ЭВМ, используемые для автоматизации разработки программ - K4р;
на подготовку и повышение квалификации специалистов-разработчиков - K5р.
Первые две составляющие K1р и K2р являются непосредственными затратами на создание программных средств. Составляющие K3р и K4р можно рассматривать как затраты, обеспечивающие оснащенность процесса создания КП. Затраты на подготовку и повышение квалификации наиболее трудно формализовать и учитывать в конкретной разработке программных средств. В данном случае эта составляющая не учитывается.
3.3 Затраты на непосредственную разработку КП
Затраты на непосредственную разработку комплекса программ K1р являются важнейшей составляющей в жизненном цикле КП. Наибольшее влияние на них оказывает объем КП. Затраты на разработку K1р и объем программ Пк связаны через показатель интегральной средней производительности труда разработчиков Р. Для учета влияния на K1р различных факторов удобно пользоваться коэффициентами изменения трудоемкости (КИТ) - Сij, учитывающими зависимость i-ой составляющей совокупных затрат от j-го фактора. Непосредственные затраты на разработку можно представить как частное от объема КП и производительность труда, корректируемое произведением коэффициентов изменения трудоемкости:
Выделим четыре основных группы факторов, влияющих на затраты K1р при непосредственной разработке программ:
факторы, отражающие особенности создаваемого комплекса программ как объекта разработки, и требования к его общим характеристикам;
факторы, характеризующие технологическую и программную оснащенность средствами автоматизации процесса разработки программ;
факторы, отражающие оснащенность процесса создания КП аппаратурными средствами, на которых базируются системы автоматизации разработки;
факторы, определяющие оснащенность процесса разработки программ и его обеспечение квалифицированными специалистами.
Для каждого фактора может быть выделен параметр, наиболее полно отражающий его содержание численными значениями. Для большинства факторов произведены оценки диапазона возможного изменения относительных затрат на разработку одной команды в КП при варьировании соответствующего параметра в указанном диапазоне. Эти изменения затрат характеризуются коэффициентами Сij изменения усредненной трудоемкости разработки строки текста программы за весь цикл создания КП при варьировании j-го фактора i-ой группы. Кроме оценок предельных значений КИТ, приводятся их средние значения.
Факторы объекта разработки |
Параметры фактора |
Диапазон изменения параметра |
Диапазон КИТ |
Среднее значение КИТ |
|
Сложность КП - С11 |
Число операторов в тексте программ на ассемблере Пк |
104 - 107 |
1 - 4 |
2 - 3 |
|
Размер базы данных |
Число типов переменных в БД |
103-108 |
1-1.2 |
1.1 |
|
Надежность функционирования КП - С13 |
Часы проработки на отказ программ Тн |
1 - 103 |
1 - 5 |
2-2.5 |
|
Ограничение ресурсов производительности и оперативной памяти реализующей ЭВМ - С14 |
Процент использования памяти и производительности Р |
50-95 |
1 - 3 |
1.3-1.5 |
|
Длительность предполагаемой эксплуатации - С15 |
Годы эксплуатации Тэ |
1 - 20 |
1 - 3 |
1.3-1.5 |
|
Предполагаемый тираж - С16 |
число предполагаемых экземпляров |
1 - 1000 |
1 - 3 |
1.3-1.5 |
|
Мобильность использования компонент КП из других разработок - С17 |
Процент возможного использования компонент |
0 - 80 |
1 - 1.4 |
1.1-1.2 |
|
Мобильность использования КП для других разработок - С18 |
Процент возможного использования компонент |
0 - 80 |
0.4 - 1 |
0.5-0.7 |
3.3.1 Факторы КП как объекта проектирования, влияющие на непосредственные затраты при разработке сложных программ
Эта группа факторов отличается наибольшим влиянием на затраты и производительность труда.
Наиболее активно в качестве показателя сложности программ используется ее объем, выраженный числом операторов на ассемблере или строк на языке программирования высокого уровня. Объем программ является одной из наиболее достоверно измеряемых характеристик КП. Логично предположить, что по мере увеличения объема КП возрастает относительная трудоемкость разработки каждой команды в программе. Такая зависимость может быть описана логарифмической функцией:
Надежность функционирования КП является наиболее важным фактором, отражающим качество программных средств.
В качестве параметров, характеризующих надежность системы, наиболее широко используется наработка на отказ Тн и коэффициент готовности Кг. Оба показателя тесно связаны, что позволяет ограничить внимание на первом из них. Изучение математических моделей процесса выявления ошибок в программах привело к тому, что одной из наиболее достоверных и простых является экспоненциальная зависимость числа оставшихся ошибок от времени ее тестирования. Эти соображения позволяют аппроксимировать средние значения С13 при повышении требований к надежности КП логарифмической зависимостью:
Ограничение ресурсов производительности и оперативной памяти реализующей ЭВМ: при использовании создаваемым КП производительности и памяти реальной ЭВМ менее чем на 50% можно и не учитывать эти ограничения, однако в нашем случае ресурсы ЭВМ используются практически полностью:
С14 = (1.14 * (1 - р)1/2)-1
где р - реальная загрузка ЭВМ ( в относительных величинах ).
Длительность предполагаемой эксплуатации КП изменяется от нескольких месяцев до нескольких лет. По экспертным оценкам, увеличение предстоящей длительности эксплуатации КП на порядок от 1 до 10 лет приводит к увеличению КИТ С15 примерно в 1.5-2 раза. Такую зависимость можно описать логарифмической функцией:
где а15 изменяется в диапазоне от 1 до 1.5.
Предполагаемый тираж программ: при переходе от уникального КП к программам, подлежащим тиражированию, затраты заметно возрастают:
Мобильность (переносимость) использования КП из других разработок позволяет снижать затраты при сборочном программировании новых КП. При этом относительное повышение производительности труда (КИТ - С17) пропорционально доле использования в новом КП. При сборочном программировании кроме 10-20% затрат на создание новых программных компонент, необходимы ресурсы на комплексирование нового КП, его комплексную отладку, испытания и документирование. В результате суммарные затраты заметно возрастают и эквивалентное повышение производительности труда С17 может составлять 2.5-3 раза. Необходимо учитывать затраты, которые требуются на создание адаптируемых компонент и всего первичного КП. В результате программная мобильность с учетом затрат на ее подготовку в среднем дает снижение КИТ на 30-50%.
Мобильность (переносимость) использования компонентов КП для других разработок приводит к необходимости их проектирования как автономных комплектующих изделий. В результате может быть достигнута возможность сборочного программирования. Для обеспечения сборочного программирования КИТ на строку в программе С18 увеличивается в среднем на 10-20%. В нашем случае неизвестно, потребуются ли в дальнейшем универсальные компоненты, поэтому С18=1.
3.3.2 Применение современных методов разработки КП
При создании данного КП использовалась пошаговая разработка компонентов программы. В этом случае интегральная оценка эффективности метода более-менее стабильна и характеризуется повышением производительности труда приблизительно на 30 - 40% (С31=0.6-0.7).
Уровень автоматизации разработки КП рассматривается прежде всего как фактор, влияющий на С1р и на производительность труда специалистов.
В нашем случае С32 = 1.
Уровень языков программирования КП. При разработке нашей программы ЯВУ (а именно - система быстрой разработки приложений Borland Delphi 3) дал увеличение производительности на 50% (С33= 0.5).
Тираж системы автоматизации разработки.
С34 = 1.
3.3.3 Факторы оснащенности процесса разработки КП аппаратурными средствами, влияющими на непосредственные затраты при разработке сложных программ
При анализе фактора аппаратурной оснащенности процесса разработки программ целесообразно учитывать интегральные характеристики всех вычислительных средств, использующих при создании данного КП. При разработке данной программы применяется только реализующая ЭВМ.
Относительное быстродействие ЭВМ на одного специалиста, участвующего в разработке КП, определяет доступный уровень автоматизации разработки программ. Влияние относительного быстродействия на полные затраты можно оценить на уровне 20-30%.(С41 = 0.7 - 0.8).
Относительный объем оперативной памяти на одного специалиста, участвующего в разработке КП, может также проявиться как заметный фактор, изменяющий производительность труда разработчиков. В нашем случае недостаточный объем памяти вызвал снижение производительности труда на 10-20% (С42 = 1.1-1.2)
3.3.4 Факторы организации процесса разработки КП, влияющие на непосредственные затраты при создании сложных программ
Индивидуальные особенности специалистов могут приводить к изменению производительности труда во много раз. В среднем технологическую квалификацию можно считать выше среднего (С52=0.7), тематическую квалификацию - как средняя (С51=0.8).
Программистская квалификация и опыт работы с языками проектирования составил 4 года ( С53 = 0.9)
Уровень квалификации заказчика высок, но техническое задание на разработку было сформировано с дальнейшими доработками (С54=1.2).
3.4 Затраты на изготовление опытного образца как продукции производственно-технического назначения
Затраты на изготовление опытного образца КП как продукции производственно-технического назначения С2р определяется необходимостью обеспечить отчуждение всего комплекса программ от его непосредственных разработчиков. Для изготовления КП как продукции производственно-технического назначения необходимо:
изготовить и оформить опытный образец КП на носителях данных;
разработать комплект документации, обеспечивающий квалифицированную эксплуатацию КП.
Для системы экономического планирования затраты K2p не имеют смысла, поскольку данная система существует в единственном экземпляре и не предполагается ее тиражировать, т.е. эти затраты не что иное как затраты на разработку данной системы.
3.5 Затраты на технологию и программные средства автоматизации разработки КП
Затраты на технологию и программные средства автоматизации разработки КП K3p обычно являются весьма весовыми только при использовании автоматизированных технологий. В нашем случае мы имеем принципиально новую систему, технология разработки которой пока не определена, поэтому затратами на технологию можно пренебречь.
3.6 Затраты на ЭВМ, используемые для автоматизации разработки данной программы.
Затраты на ЭВМ, используемые для автоматизации разработки данного КП - С4р включают капитальные затраты на закупку и установку соответствующих ЭВМ, а также текущие затраты на их эксплуатацию в течении разработки КП.
В нашем случае затраты распределяются только на эксплуатацию ЭВМ в течение разработки КП. Поэтому общие затраты на ЭВМ будут выглядеть как:
С4р = С4р1 = а41*Тр.
Где а41 - стоимость машинного времени реализующей ЭВМ.
3.7 Расчет затрат на разработку системы моделирования макроэкономики
3.7.1 Исходные данные
ограничение ресурсов производительности и оперативной памяти реализующей ЭВМ не менее 90%;
предположительно длительность эксплуатации составит не более 1 года;
данная программа будет существовать в единственном экземпляре;
после создания КП предполагается использовать около 60% наработок;
при создании КП число наработок из других программ составило не более 30%;
при разработке программы, которая относится к программному продукту ниже среднего класса сложности, применялась только реализующая ЭВМ;
уровень квалификации заказчика выше среднего.
Наименование характеристики |
Количество |
|
Количество программистов, S |
6 чел. |
|
Оклад программиста, Sм |
2000 руб./ мес. |
|
Объем программы, П |
13129 строк |
|
Стоимость одного часа машинного времени, а41 |
20 руб./ч |
|
Общее время разработки, Tр |
~ 4 мес. |
|
Количество машинного времени, затраченного в день, Тдн |
3 ч/день |
3.7.2 Коэффициенты изменения трудоемкости
сложность программы - С11 = lg(4693.5 * 10-3)=0.67;
ограничение ресурсов производительности ЭВМ -
С14 = (1.14 * (1 - р)1/2)-1 = 2.8;
мобильность использования компонент из других разработок - С17=0.7;
современные методы разработки - С31 = 0.7;
уровень языка программирования - С33 = 0.5;
относительное быстродействие ЭВМ - С41 = 0.8;
относительный объем памяти - С42 = 1.1;
технологическая квалификация - С51 = 0.7;
тематическая квалификация - С52 = 0.8;
программистская квалификация - С53 = 0.9;
квалификация заказчика - С54 = 1.2;
остальные коэффициенты примем равными единице.
3.7.3 Расчет непосредственных затрат на разработку
Считаем, что на каждого разработчика пришлось одинаковое число команд - П * 1.5 / 6 команд, т.е. считаем, что в одной строке содержится в среднем 1.5 команды и, т.к. в разработке принимало участие шесть человек, то в результате стыковки модулей общее количество строк составило сумму количества строк каждого разработчика.
Пк = П *1.5 / 6 = 3282 (команд/чел.);
Производительность P = Пк / Тр = 2.07 (команд/чел./день);
Считаем, что в месяце, в среднем, 22 рабочих дня, тогда средняя дневная заработная плата разработчика Sд = 90.9 (руб.)
Произведение коэффициентов Сij - Пij Cij = 0.245;
Также необходимо учитывать накладные расходы, включающие в себя:
заработную плату административно - управленческого персонала с отчислением на социальное страхование;
аренду помещения;
хозяйственные нужды;
приобретение специальной литературы.
Считаем, что накладные расходы составили 50% от непосредственных затрат.
Теперь можем рассчитать непосредственные затраты на разработку - К1р :
K1р = Пк * ПijCij * Sд * S * 1.5 / P = 522 * 0.245 * 90.9 * 6 * 1.5 / 2.07 = 50544 (рублей).
Затратами на создание опытного образца являются затраты на разработку, т.е. программа сама по себе и есть опытный образец. Затратами на технологию и программные средства мы пренебрегаем.
3.7.4 Затраты на ЭВМ
Считаем, что в году 250 рабочих дней.
Тр = 84 (дней);
Рассчитаем затраты на ЭВМ:
К4р = а41*Тр * Tдн = 20 * 84*3 = 5040 (руб.)
Все результаты сведем в таблицу.
Затраты на разработку КП
Составляющие |
Затраты (руб.) |
% от затрат на разработку |
|
K1р |
50544 |
90 |
|
K4р |
5040 |
10 |
Таким образом затраты на разработку системы моделирования макроэкономики составляют Kр = 55584 руб.
3.8 Выводы
Мы рассчитали суммарные затраты на разработку данного Кп и увидели, что они составили примерно 55584 рублей. Наибольшие затраты были на разработку программы, кроме того, очень высокий процент непосредственных затрат на эксплуатацию реализующей ЭВМ. Это может объясняться тем, что еще не отработана технология на создание подобных систем.
Возможным методом уменьшения затрат является более продуктивное использование машинного времени программистами.
Глава 4
ПЭБ
“Организация рабочего места программиста”
4. Организация рабочего места программиста
4.1 Условия производственно-экологической безопасности разработчика пользователя ЭВМ
В этой части рассматриваются факторы, влияющие на условия безопасности труда разработчиков - пользователей ЭВМ. Приводятся их основные характеристики и рекомендации по преодолению или ограничению вредного воздействия аппаратуры, входящей в состав рабочего места пользователя ЭВМ.
4.2 Вредные воздействия при работе с компьютером
Работая за дисплеем компьютера человек подвергается воздействию различных факторов. К таким воздействиям можно отнести следующие:
электромагнитное излучение;
тепловое излучение;
недостаток или избыток общей освещенности;
механическое воздействие;
шумовое воздействие;
опасность поражения электрическим током.
Наличие подобных факторов обусловлено предметами и средствами труда программиста, к которым можно отнести следующее оборудование:
системная часть компьютера;
дисплей;
принтер;
электрооборудование рабочего места
другие внешние устройства.
Особенно сильно проявляется влияние дисплея компьютера. Дисплей принадлежит к числу тех компонентов, работа с которыми требует особенного внимания. Практически большую часть времени работы за компьютером человек смотрит на экран, или, по крайней мере, находится перед ним, подвергаясь таким образом воздействию электромагнитного излучения, уровень которого целиком зависит от качества электронных лучевых трубок (ЭЛТ), которое еще не всегда удовлетворительное. Поэтому вопросам организации рабочего места следует уделить первостепенное внимание.
4.3 Факторы обитаемости
1) Физические факторы обитаемости:
электрическая опасность;
тепловое излучение;
электромагнитное излучение;
освещенность;
шумовое воздействие;
микроклимат.
2) Психофизические факторы обитаемости:
монотонность труда;
статические нагрузки;
перенапряжение зрения;
умственное перенапряжение.
Для количественной характеристики некоторых из этих факторов можно привести следующие цифры:
1) Электроопасность : 0.5 - 0.8 ампера при предельно допустимой норме 0.01 ампера.
2) Электромагнитное излучение : до 1.5 В/А при норме 50 В/А.
3) Звуковое воздействие : до 37 дБ при норме до 54 дБ.
4) Тепловое воздействие : средняя температура 22 - 24 градуса при норме до 26 градусов.
4.4 Воздействие электромагнитного излучения монитора
С начала 1990-х годов самые широкие круги пользователей компьютеров осознали, наконец, истинную серьезность вопроса о возможной опасности воздействия на организм электромагнитных излучений дисплейных мониторов. В настоящее время ведутся медицинские и научные исследования с тем, чтобы исследовать данную проблему и выработать по отношению к ней единое мнение.
Спектр излучения компьютерного монитора включает в себя рентгеновскую, ультрафиолетовую и инфракрасную область, а также широкий диапазон электромагнитных волн других частот. От рентгеновских лучей опасности практически нет, так как они полностью поглощаются веществом экрана. Наибольшую опасность представляют биологические эффекты низкочастотных электромагнитных полей, которые до настоящего времени считались абсолютно безвредными. В ряде экспериментов было обнаружено, что электромагнитные поля с частотой 60 Гц могут инициировать биологические сдвиги (вплоть до нарушения синтеза ДНК) в клетках животных. В отличие от рентгеновских лучей электромагнитные волны обладают необычным свойством - опасность их воздействия не обязательно уменьшается с уменьшением интенсивности облучения; определенные электромагнитные волны действуют на клетку лишь при малой интенсивности излучения или в конкретных частотах - в окнах прозрачности.
Исследователи из Macworld обнаружили, что если на расстоянии 10 см перед мониторами, обычно используемыми с компьютерами Macintosh, напряженность магнитного поля составляет примерно от 5 до 23 мГс, то на расстоянии 70 см от экрана ни у одного из обследованных мониторов напряженность поля не превышала величины 1 мГс. (Интенсивность поля вне указанных пределов составляла 0.1 - 0.5 мГс.) Пользователям Macintosh, желающим снизить уровень облучения переменными магнитными полями, следует расположить мониторы так, чтобы расстояние до них составляло величину, равную длине вытянутой руки (с вытянутыми пальцами).
Поскольку магнитные поля сзади и по бокам большинства мониторов значительно сильнее, чем перед экраном, пользователи должны располагать свои рабочие места на расстояниях не менее 1,22 м от боковых и задних стенок других мониторов. Следует иметь в виду, что магнитное излучение не задерживается ни перегородками, ни стенками, ни свинцовыми фартуками, ни даже телом человека.
4.5 Оптимизация условий зрительного восприятия
Эффективность зрительного восприятия зависит от ряда условий. Чтобы видеть и различать объект при нормальной остроте зрения необходимо обеспечить:
определенный уровень освещенности и размера объекта, необходимая контрастность фона;
достаточный размер объекта;
необходимую экспозицию, т. е. время различения объекта.
Оптимальное расстояние от глаза до объекта наблюдения зависит от линейной величины рассматриваемого объекта и остроты зрения. При работе за дисплеем это расстояние обычно равно 35 - 60 см. Пользователь обычно работает с текстовой информацией, поэтому символы на экране должны быть увеличены в 1.5 - 2 раза по сравнению с печатным текстом.
Для пользователя ЭВМ зрительное восприятие играет очень большую роль. Это предъявляет значительные требования к освещенности рабочего места, так как во многом именно от освещенности рабочего места зависит степень утомляемости человека.
4.6 Освещение
Система освещения машинного зала ПЭВМ должна отвечать следующим основным требованиям:
Уровень освещенности рабочих мест должен соответствовать характеру выполняемых работ.
Достаточно равномерное распределение яркости на рабочих поверхностях и в окружающем пространстве.
Отсутствие резких теней, прямой и отраженной блескости.
Постоянство освещенности во времени.
Оптимальная направленность светового потока.
Долговечность, экономичность, электро- и пожаробезопасность, эстетичность, удобство и простота эксплуатации.
Для обеспечения нормальной естественной освещенности, площадь оконных проемов должна быть не менее 25% площади пола.
Строительные нормы и правила СНиП II-4-79 устанавливают следующие нормы искусственной освещенности рабочих мест (с высотой рабочей поверхности над полом 80 см):
Норма освещенности:
а) при комбинированном освещении - 750 лк;
б) при общем освещении - 400 лк;
Коэффициент пульсаций освещенности рабочего места Кп ? 15%.
Рекомендуемая освещенность при работе с дисплеем составляет 200 лк, а при работе с экраном в сочетании с работой над документами -400 лк. Рекомендуемые перепады яркости в поле зрения оператора должны лежать в пределах 1:5 - 1:10.
Расчет общего освещения
Рассчитаем общее освещение в машинном зале ПЭВМ методом коэффициента использования светового потока по уравнению:
1. Выбираем рекомендованное для машинного зала люминесцентное освещение.
2. Располагаем светильники рядами вдоль длинной стороны помещения.
3. Будем использовать светильники типа УСП-35 с двумя лампами типа ЛБ-40.
4. Для обеспечения наилучших условий освещения, расстояние между рядами светильников L должно соответствовать отношению:
где h-высота подвеса светильников,
где H = 3.0 м - высота помещения,
hc = 0.2 м - свес светильника,
hp = 0.75 м - высота рабочей поверхности от пола.
h = 3.0-0.2-0.75 = 2.05 [м]
L = л*h = 2.3 … 3.4 [м]
5. Количество рядов светильников N найдем из уравнения:
L * (0.33* 2 + N-1) = B
N = 2 ряда.
Согласно нормам, нормируемая минимальная освещенность при общем освещении: Eн = 400 лк.
Так как запыленность воздуха меньше 1 мг/мі, то коэффициент запаса:
кз = 1.5.
Площадь помещения S = A*B = 6*4 = 24 [мІ].
Так как мы предполагаем создать достаточно равномерное освещение, то коэффициент неравномерности освещения: z = 1.15.
Индекс помещения:
6. Коэффициенты отражения светового потока принимаем:
от потолка сп = 70%,
от стен сс = 50%,
от пола спола = 10%.
Тогда по таблице находим коэффициент использования светового потока: з = 0.46.
7. Так как затенения предполагаем не создавать, то коэффициент затенения: г = 1.
8. По таблице находим световой поток лампы ЛБ-40: Фл = 3120 лм.
9. Количество светильников в одном ряду:
Расположение светильников:
Длина светильника lсв = 3 м
Количество светильников в ряду М = 3 шт
Длина помещения А = 6 м
Количество рядов светильников N = 2 шт
Ширина помещения В = 4 м
Так как А - М*lсв = 2.1<4*L = 9.2 [м] (где L - рассчитанное минимальное расстояние между светильниками), то расстояние между светильниками в одном ряду L2 можно сделать равным расстоянию от крайнего светильника в ряду до стены. Тогда
Расстояние между рядами L1 при расстоянии крайнего ряда от стены 0.33*L1:
Итак, для нормального освещения машинного зала ПЭВМ используем 6 светильников типа УСП-35 с двумя лампами типа ЛБ-40.
4.7 Микроклимат
Параметры микроклимата согласно ГОСТ 12.1.005-88 являются:
температура;
относительная влажность;
скорость движения воздуха;
запыленность воздуха.
С целью обеспечения комфортных условий для операторов ПЭВМ и надежной работы оборудования, необходимо поддерживать следующие метеорологические условия (согласно СН 512-78):
Параметры воздушной среды на рабочих местах |
|||||||
Температура |
Оптимальные |
Допустимые |
|||||
Наружного воздуха, °С |
Температура, °С |
Относительная влажность, % |
Скорость движения воздуха, не более, м/c |
Температура, °С |
Относительная влажность, % |
Скорость движения воздуха, не более, м/c |
|
Ниже +10 |
20-22 |
40-60 |
0.2 |
18-22 |
Не более 70 |
0.3 |
|
Выше +10 |
20-25 |
40-60 |
0.3 |
Не более, чем на 3 °С выше наружного воздуха в 13 ч дня самого жаркого месяца, но не выше 28 °С |
70 при 24 °С и ниже; 65 при 25 °С; 60 при 26 °С; 55 при 27 °С; 50 при 28 °С. |
0.5 |
Атмосферное давление в помещении машинного зала должно быть 1013.25±266 ГПа. При пониженном давлении воздуха ухудшается отвод теплоты от элементов ПЭВМ, снижаются изоляционные свойства воздуха.
Воздух, используемый для вентиляции машинного зала, должен очищаться от пыли. Запыленность воздуха не должна превышать 1 мг/мі, а размеры пылинок - 3 мкм. Пыль, попадающая на платы комплекса, приводит к снижению теплообмена и способствует перегреву приборов.
В помещении машинного зала необходимо предусмотреть систему отопления. Она должна обеспечивать достаточное, постоянное и равномерное нагревание воздуха в помещении в холодный период года, а также безопасность в отношении пожара и взрыва. При этом колебания температуры в течении суток не должны превышать 2-3 °С; в горизонтальном направлении - 2 °С на каждый метр длины; а в вертикальном - 1 °С на каждый метр высоты помещения. Для отопления помещения машинного зала рекомендуется использовать водяные или воздушные системы центрального отопления.
Дежурное отопление должно включаться в помещении машинного зала ночью, в выходные и праздничные дни и, когда ПЭВМ не работают. Оно должно поддерживать в зале температуру воздуха в пределах 15-16 °С.
4.8 Оптимизация акустических условий
Работающие ЭВМ и мини ЭВМ могут являться источниками шума на предприятиях. Шум неблагоприятно действует на организм человека, вызывая различные физиологические отклонения в организме, психологические заболевания и снижает работоспособность. Утомление пользователей и операторов ЭВМ из-за шума увеличивает число ошибок при работе, способствует возникновению травм.
Шум - это совокупность звуков различной частоты и интенсивности. Характеристикой шума с точки зрения физиологического восприятия является понятие "громкость шума". Количественную оценку уровня громкости шума различных источников проводят путем сравнения с шумом на частоте 1000 Гц, для которого уровень силы принят равным уровню громкости. При этом для измерения уровня громкости шума введена единица в 1 фон. За один фон принят уровень громкости шума с частотой 1000 Гц при уровне силы шума 1 дб.
ГОСТ 12.1.003-83 "Шум, общие требования безопасности" устанавливает, что уровень звука на рабочем месте (в том числе при работе на ЭВМ) не должен привыкать 50 дб.
Источниками шума в системах с ЭВМ являются периферийные устройства: принтеры, плоттеры, дисководы, системы охлаждения (вентиляторы), которые создают уровень шума до 70 - 80 дб. Для уменьшения уровня шума желательно устанавливать дисплеи в других помещениях, отдельно от машин. Это связано с тем, что воздействие шумов оказывает неблагоприятное влияние на эмоциональный настрой и вызывает сильные сопутствующие раздражения, повышающие рабочую нагрузку и снижающие творческий потенциал. Как следствие возрастает число ошибок. По данным американских журналов увеличение шума на 10 дб ведет к возрастанию числа ошибок на 30 - 40%.
Подобные документы
Особенности разработки инфологической модели и создание структуры реляционной базы данных. Основы проектирования базы данных. Разработка таблиц, форм, запросов для вывода информации о соответствующей модели. Работа с базами данных и их объектами.
курсовая работа [981,4 K], добавлен 05.11.2011Требования, предъявляемые к инфологической модели, ее компоненты. Построение модели и диаграммы "объект — свойство — отношение". Три типа бинарных связей. Подтипы и супертипы сущностей в языках программирования. Каскадные удаления экземпляров сущностей.
лекция [404,3 K], добавлен 17.04.2013Понятие, задачи и требования к разработке базы данных. Типы моделей данных, их преимущества и недостатки и обоснование выбора модели. Процесс учета студентов в больнице, описание структуры базы данных, перечень групп пользователей и доступа к данным.
курсовая работа [45,1 K], добавлен 09.03.2009Характеристика сущностей инфологической модели и проектирование модели базы данных технологического процесса. Описание предметной области и основы инфологического моделирования. Особенности проектирования и обеспечение выполнения объявленных функций.
курсовая работа [22,5 K], добавлен 27.02.2009Процесс проектирования базы данных на основе принципов нормализации. Применение инфологической модели на втором этапе проектирования. Семантика предметной области в модели базы данных. Оформление, выдача и обмен паспорта. Модель "сущность-связь".
курсовая работа [67,9 K], добавлен 27.02.2009Процесс проектирования с использованием принципов нормализации. Определение сущности "Группа" в модели ER. Моделирование связи между сущностями "Студент" и "Группа" и предметной области "Учебный процесс". Применение инфологической модели в проекте.
курсовая работа [33,8 K], добавлен 27.02.2009Системный анализ и анализ требований к базе данных. Концептуальная и инфологическая модель предметной области. Типы атрибутов в логической модели базы. Физическая модель проектируемой базы данных в методологии IDEF1X. Требования к пользователям системы.
курсовая работа [2,3 M], добавлен 21.11.2013Обзор средств проектирования баз данных. Технологические платформы баз данных. Основные этапы проектирования. Разработка логической и физическойц модели. Генерация модели в MS Access 2003. Реализация форм и запросов базы данных. Требования по установке.
курсовая работа [3,0 M], добавлен 28.12.2015Определенная логическая структура данных, которые хранятся в базе данных. Основные модели данных. Элементы реляционной модели данных. Пример использования внешних ключей. Основные требования, предъявляемые к отношениям реляционной модели данных.
презентация [11,7 K], добавлен 14.10.2013Создание базы данных "Автовокзал" как части информационной системы. Требования к базе данных и этапы ее разработки. Анализ информационных потоков, выбор модели. Входные и выходные данные. Программирование базы данных на языке Borland Delphi 7.0.
курсовая работа [105,8 K], добавлен 16.05.2011