<?xml version="1.0" encoding="UTF-8"?>
<course>
  <academic-career-val type="integer">1</academic-career-val>
  <assumed-knowledge-and-required-skills></assumed-knowledge-and-required-skills>
  <available-through-customised-graduate-programs type="integer" nil="true"></available-through-customised-graduate-programs>
  <co-teaching-course-id type="integer" nil="true"></co-teaching-course-id>
  <consent-description></consent-description>
  <consent-required type="boolean">false</consent-required>
  <corequisites></corequisites>
  <cost-considerations></cost-considerations>
  <course-code>COMP1510</course-code>
  <course-description>&lt;p&gt;This course introduces students to the tools and techniques for developing software systems of a size and quality of an industrially relevant nature. The course teaches the fundamental strategies of abstraction, decomposition and reuse as methods for constructing such systems. Verification and validation techniques, with an emphasis on testing, are taught as a means to ensure that students are able to deliver software products of the quality required. It also introduces students to the principles and practices of software engineering.&lt;/p&gt; &lt;p&gt;In particular, the course will cover: recursive data structures and algorithms; structured data types, abstract data types and their applications; object-oriented programming; and software life-cycle. The course will also introduce some of the theoretical fundamentals that underpins software engineering, including: reasoning about software and its application to specifications, and verification and validation.&lt;/p&gt;</course-description>
  <course-group nil="true"></course-group>
  <eligibility></eligibility>
  <filled-flag type="integer">1</filled-flag>
  <first-year-course type="boolean">false</first-year-course>
  <id type="integer">10765</id>
  <incompatibility>&lt;p&gt;COMP1110 and COMP2750&lt;/p&gt; </incompatibility>
  <indicative-assessment>Assignment (30%); Lab Tests (20%); Final Exam (50%)  </indicative-assessment>
  <indicative-reading-list></indicative-reading-list>
  <is-active type="integer">1</is-active>
  <is-public type="integer">1</is-public>
  <learning-outcomes> Upon completion of this course, the student will be able to:   &lt;ul&gt;&lt;li&gt;complete the implementation of an Program, given as specification of the        required behaviour of the class.&amp;nbsp; &lt;/li&gt;&lt;li&gt;analyze alternatives among simple data-structures -- lists, tables, and trees,      for example -- and select the most appropriate structure for a simple task.&amp;nbsp; &lt;/li&gt;&lt;li&gt;analyze alternatives among simple algorithms -- sorting and searching,      for example -- and select the most appropriate for a simple task.&amp;nbsp; &lt;/li&gt;&lt;li&gt; rigorously analyze the correctness of a simple program fragment       given a logical description of its required behaviour.&amp;nbsp; &lt;/li&gt;&lt;li&gt; apply their knowledge of regular expressions to devise a regular       expressions to match target phrases.&amp;nbsp; &lt;/li&gt;&lt;li&gt; apply their knowledge of testing principles to select appropriate       test data for an individual software routine. &lt;/li&gt;&lt;li&gt; identify economic implications of the software life cycle to the       process of software construction.&amp;nbsp; &lt;/li&gt;&lt;li&gt; identify the invariant of a simple loop.&amp;nbsp; &lt;/li&gt;&lt;li&gt; apply the technique of recursion to implement simple      requirements. &lt;/li&gt;&lt;li&gt;  understand some of the complexities of multi-threading&amp;nbsp; &lt;/li&gt;&lt;li&gt;  work in a group to complete an assigned task&amp;nbsp; &lt;/li&gt;&lt;li&gt;  independently use selected writings in computing to analyse and        explain technical computing problems.&amp;nbsp; &lt;/li&gt;&lt;/ul&gt;</learning-outcomes>
  <lock-version type="integer">0</lock-version>
  <long-title>Introduction to Software Engineering</long-title>
  <max-units type="integer">6</max-units>
  <min-units type="integer">6</min-units>
  <other-information></other-information>
  <preliminary-reading></preliminary-reading>
  <prescribed-texts>&lt;p&gt;Carrano, Frank, et. al &lt;em&gt;Data Abstraction and Problem Solving with Java&lt;/em&gt;, Addison Wesley, second edition, 2006&lt;/p&gt;Horstmann, Cay &lt;em&gt;Big Java&lt;/em&gt;, Wiley, 3rd Edition, 2008</prescribed-texts>
  <progress-units type="integer">6</progress-units>
  <quota></quota>
  <recommended-courses></recommended-courses>
  <requisite-statement>&lt;p&gt;Enrolment in BSEng; COMP1100&lt;/p&gt;</requisite-statement>
  <restricted-program-entry type="integer" nil="true"></restricted-program-entry>
  <short-title>Introduction to Software Eng</short-title>
  <student-contribution-band>Band 2</student-contribution-band>
  <subject>Computer Science</subject>
  <technology-requirements></technology-requirements>
  <updated-by nil="true"></updated-by>
  <version type="integer" nil="true"></version>
  <workload>&lt;p&gt;Thirty one-hour lectures, nine&amp;nbsp;two-hour tutorial/laboratory sessions and three two-hour seminars.&lt;/p&gt;</workload>
  <year type="integer">2010</year>
</course>
