1. Homepage
  2. Programming
  3. FIT1047: Introduction to computer systems, networks and security - Assignment 3: Processes and MARIE Programming

FIT1047: Introduction to computer systems, networks and security - Assignment 3: Processes and MARIE Programming

Engage in a Conversation
澳洲AustraliaFIT1047 networks and securityIntroduction to computer systemsMonash UnversityMARIEAssembly

Assignment 3 – Processes and MARIE Programming CourseNana.COM

This assignment has two parts. Make sure you read the instructions carefully. CourseNana.COM

Part 1: Processes (10 marks) CourseNana.COM

For this task, write a brief report about processes that you observe running on your computer. You can use one of the following tools (depending on your operating system): CourseNana.COM

On Windows, use the Task Manager
On macOS, use the Activity Monitor
On Linux, use a command line tool like htop, top, or the ps command
CourseNana.COM

Answer the following questions: CourseNana.COM

  1. Briefly describe the columns displayed by the tool you use that relate to a) memory usage and b) CPU usage of a process. What can you say about the overall memory usage of all processes, compared to the RAM installed in your computer? (4 marks)
  2. Pick a process you perhaps don’t know much about, or which you did not expect tofind running on your computer. Try to find out and describe briefly what it does. (4 marks)
  3. Briefly explain why it is important that the operating system manages the files stored on your computer (rather than each application having to manage those files itself). (2 marks)

Include a screenshot of your processes in the report along with utilization graphs. The word limit for this part (all three questions together) is 600 words (about 1 page, not including images and tables). CourseNana.COM


CourseNana.COM


CourseNana.COM

Part 2: MARIE Programming (40 marks) CourseNana.COM

In this task you will develop a MARIE application that performs some manipulation of strings.We will break it down into small steps for you. You need to submit a working MARIE program for each individual task and you will get marks for each separate program. CourseNana.COM

Each task requires you to write code and test cases. On Moodle, you will find a template for the code for tasks 2.2 and one template for the remaining tasks. Your submission must be based on these templates, i.e., you must add implementations of your own subroutines into these templates. CourseNana.COM

The code must contain comments, and you need to submit one zip file containing one .mas file for each task together with the rest of your assignment. CourseNana.COM

In-class interviews: You will be required to demonstrate your code to your tutor during yourapplied session after the submission deadline. Failure to demonstrate will lead to zero marks being awarded for the entire assignment. CourseNana.COM

Code similarity: We use tools to check for collaboration and copying between students. If you copy parts of your code from other students, or you let them copy parts of your code, you will receive 0 marks for the entire assignment. CourseNana.COM

Rubric: The marking rubric on Moodle provides details for the marking. Each task below is worth a certain number of marks. A correctly working MARIE program of each task that is well documented and contains the required test cases will receive full marks. Missing/incomplete documentation will result in a loss of up to 1⁄4 of the task’s marks. Missing or undocumented test cases result in the loss of 1 mark per test case. CourseNana.COM


CourseNana.COM

CourseNana.COM

Introduction: Strings CourseNana.COM

A string is a sequence of characters. It's the basic data structure for storing text in a computer. There are several different ways of representing a string in memory -- e.g. usually you would need to decide which character set to use, and how to deal with strings of arbitrary size. CourseNana.COM

For this assignment, we will use the following string representation:
A string is represented in a contiguous block of memory, with each address containing one character.
The characters are encoded using the ASCII encoding, this means you need to use the hexadecimal numbers for the ASCII characters. Note that MARIE provides Unicode (UTF-16BE) as an option, but the first 128 characters are the same as the ASCII coded characters,
The end of the string is marked by the value 0.
CourseNana.COM

As an example, this is how the string FIT1047 would be represented in memory (written as CourseNana.COM

CourseNana.COM

hexadecimal numbers):
046 049 054 031 030 034 037 000
CourseNana.COM

Note that for a string with n characters, we need n+1 words of memory in order to store the additional 0 that marks the end of the string. CourseNana.COM

In MARIE assembly, we can use the HEX keyword to put this string into memory: CourseNana.COM

FIT1047, HEX 046 HEX 049 CourseNana.COM

HEX 054 HEX 031 HEX 030 HEX 034 HEX 037 HEX 000 CourseNana.COM

Task 2.1 Your name as a MARIE string (2 points) CourseNana.COM

Similar to the FIT1047 example above, encode your name using ASCII characters. You should encode at least 10 characters -- if your name is longer, you can shorten it if you want, if it's shorter, you need to add some characters (such as !?! or ..., or invent a middle name including space). CourseNana.COM

You need to submit a MARIE file that contains the code that stores your name into memory. CourseNana.COM

Note that this code will not actually do anything else than storing your name in memory and you will not need to use the template for this. CourseNana.COM

Task 2.2 Printing a string (4 points) CourseNana.COM

For this task, you need to write MARIE code that can print any string (no matter how long) using the Output instruction. Start by using a label CurrentCharacterAddress that you initialize with the address of the string (for example with StringtobePrinted in the template). The code should then output the character at the address, increment it by one, and keep doing that until the character at the address is a 0 (which signals the end of the string). CourseNana.COM

Submit your MARIE code that shows the test case of printing your name from the previous task. CourseNana.COM

Task 2.3: A subroutine for printing a string (4 points) CourseNana.COM

Turn your code from the previous task into a subroutine that takes the address of a string as an argument and outputs it. Use the template for this task.
Your code needs to start reading the string from the address stored in PrintString, stopping when it finds a 0, otherwise printing the character using the Output instruction.
CourseNana.COM

Submit your MARIE code, including a test case that calls the subroutine with the address of the string representing your name. Document your test with a screen shot showing MARIE memory after executing the code.
Hint: You need to find out the concrete address by first assembling your code and then looking up where the string ended up being placed in memory, then adapt your code). CourseNana.COM

Task 2.4: User input (5 points) CourseNana.COM

The next step is to implement a subroutine that reads a string, character by character, usingthe Input instruction. The subroutine takes an address as its argument which is the location in memory where the string should start. Your code needs to input a character, store it at a given address (use the last two digits of your student ID in HEX with prefix ‘1’, for example, if last two digits of student ID is 01 then 101), then increment the address by 1 and loop back to the input. Once a user enters a 0, the subroutine finishes. CourseNana.COM

Note that you can switch the input box in the MARIE simulator into different modes: use the UNICODE mode to enter the characters, and use Hex or Decimal to enter the final 0 (sincethe character ‘0’ is different from the integer 0). CourseNana.COM

Submit your MARIE code. Document at least two test cases using screenshots of what the memory looks like after entering a string. CourseNana.COM

Task 2.5 Lower case (5 points) CourseNana.COM

Some people write emails with lots of uppercase characters, which is a bit rude and unpleasant to read. So we will implement a subroutine that turns all characters in a string into lower case. CourseNana.COM

The subroutine takes the address of a string as its argument. For each character in the string, it tests whether it is upper case (i.e., whether it is between the ASCII values for A and Z), and if it is, it turns it into lower case (modifying the string stored in memory). It finishes when it reaches the 0 signaling the end of the string. CourseNana.COM

Hint: to turn a character from upper case into lower case, just add the difference between the ASCII values for "a" and "A". CourseNana.COM

Submit your MARIE code and documentation of two test cases (i.e. document your Input into the program and the output you observe, so that it can be repeated during the interview. CourseNana.COM

Task 2.6 ROT13 (12 points) CourseNana.COM

Now we combine the previous subroutines and add another subroutine that implements a simple substitution cipher known as ROT13. The idea is to replace each character in a string by the character 13 places further in the alphabet, wrapping around from z to a. For example, the letter a is mapped to n, and the letter p is mapped to c. CourseNana.COM

Your task is to implement a subroutine that performs ROT13 encoding on a string with lowercase letters. It does not need to work or provide any meaningful output on wrong input, e.g. upper case or other characters. CourseNana.COM

For example: CourseNana.COM

Input: abp Output: noc CourseNana.COM

Input: abp?A! Output: noc?A! CourseNana.COM

Thus, for this task you need to do the following:
Implement a subroutine that can do ROT13 on a string that contains only lower case letters.
Combine the new subroutine and all the previous subroutines into a program that does the following:
CourseNana.COM

  • Let a user input a string (input one character at a time)
  • Perform ROT13 on the string
  • Output the result

Submit the complete MARIE code and document 3 test cases. CourseNana.COM

Task 2.7 Extend the ROT13 code to work for all ASCII characters (8 points) CourseNana.COM

For this task, you need to extend the ROT13 subroutine in your code from Task 2.6 to ignore all characters that are not lower case letters. Thus, your new program should apply ROT13 to all letters and keep other characters as they are (remember that upper case letters are turned into lower case before applying ROT13). CourseNana.COM

For example: CourseNana.COM

Input: abp?A! Output: noc?n! CourseNana.COM

Thus, for this task you need to do the following:
Implement a subroutine that can do ROT13 on a string that contains any ASCII characters.
Combine the new subroutine and all the previous subroutines into a program that does the following:
CourseNana.COM

  • Let a user input a string (input one character at a time)
  • Turn all letters into lower case (keep other characters as they are)
  • Perform ROT13 on the string
  • Output the result.

Submit the complete MARIE code and document 3 test cases. CourseNana.COM

  CourseNana.COM

Get in Touch with Our Experts

WeChat (微信) WeChat (微信)
Whatsapp WhatsApp
澳洲代写,Australia代写,FIT1047代写, networks and security代写,Introduction to computer systems代写,Monash Unversity代写,MARIE代写,Assembly代写,澳洲代编,Australia代编,FIT1047代编, networks and security代编,Introduction to computer systems代编,Monash Unversity代编,MARIE代编,Assembly代编,澳洲代考,Australia代考,FIT1047代考, networks and security代考,Introduction to computer systems代考,Monash Unversity代考,MARIE代考,Assembly代考,澳洲help,Australiahelp,FIT1047help, networks and securityhelp,Introduction to computer systemshelp,Monash Unversityhelp,MARIEhelp,Assemblyhelp,澳洲作业代写,Australia作业代写,FIT1047作业代写, networks and security作业代写,Introduction to computer systems作业代写,Monash Unversity作业代写,MARIE作业代写,Assembly作业代写,澳洲编程代写,Australia编程代写,FIT1047编程代写, networks and security编程代写,Introduction to computer systems编程代写,Monash Unversity编程代写,MARIE编程代写,Assembly编程代写,澳洲programming help,Australiaprogramming help,FIT1047programming help, networks and securityprogramming help,Introduction to computer systemsprogramming help,Monash Unversityprogramming help,MARIEprogramming help,Assemblyprogramming help,澳洲assignment help,Australiaassignment help,FIT1047assignment help, networks and securityassignment help,Introduction to computer systemsassignment help,Monash Unversityassignment help,MARIEassignment help,Assemblyassignment help,澳洲solution,Australiasolution,FIT1047solution, networks and securitysolution,Introduction to computer systemssolution,Monash Unversitysolution,MARIEsolution,Assemblysolution,