CMT304 Programming Paradigms - Cardiff University - Script

Post New Homework

Assignment

Task 1: Script programming

Consider the following situation:

You are given a directory from a webserver that contains multiple HTML files as well as multiple files of other types (e.g. images). The directory may contain subdirectories. You are asked to clean up this directory and its subdirectories by removing all unused files. A file is considered unused if it is not linked in any of the HTML files or if it is not specified explicitly that this file is in use. A file can be linked in a HTML file by either a href or img src. It does not matter whether the link is within a commented-out section of the HTML file. Do not remove subdirectories.

The files you remove must be stored in a user-specified directory. You need to maintain the directory structure when storing the removed files (e.g. if you remove two files a/b/a.txt and a/a.txt, both files must be stored under their directories).

You also need to create statistics output for the files that have been removed. The statistics output must be in text form and must contain, for each file ending, the number of files and the overall size of files with that ending. In addition, the number and size of all removed files needs to be reported. For this purpose, file- endings are not case-sensitive (i.e. .gif and .GIF are considered the same for statistics purposes). The statistics must also contain the name of the directory on which the cleanup script has been run.

T1.1: Write a Perl script to automate task. The script must be run as follows: cleanup.pl [CleanupDir] [RubbishBinDir] [ListOfUsedFiles] where

[CleanupDir ] is the name of the directory to clean up.
[RubbishBinDir ] is the name of the directory where removed files are to be stored.
[ListOfUsedFiles ] is a list of 0 or more files that are in use and should not be deleted.

Your script must handle errors such as missing parameters, missing files, missing di- rectories, missing access permissions, or input/output errors gracefully, that is, it must not crash on encountering them. Depending on what is appropriate, your script may handle errors by displaying a warning and continuing, by displaying an error message and aborting, or by taking other actions (e.g. creating a missing directory). Your script should try to fix problems, if this is possible.

T1.2: Discuss, in at most 300 words, why script programming is particularly suited for this problem, and describe two possible extensions of your script and how they could be achieved.

Task 2: Quantum computing

Consider the following (incomplete) quantum circuit:

2041_figure.jpg

M represents the act of making a measurement on the first two qubits. The circuit is sup- posed to transfer the state |ψ) = a |0) + b |1) (a, b ∈ C) from the first qubit to the third qubit, involving a classical operation to select a quantum gate.

Depending on the measurement outcome of the first two qubits, what quantum gate should be applied in place of ‘?', such that the transfer is successful? Provide a table containing the measurement results of M and the quantum gate to be applied in each case. Justify that your answer is correct by showing the operation of the circuit up to the execution of M and the state of the third qubit depending on the result of M .

Also discuss, in at most 300 words, whether it is possible to create a copy of |ψ) without any classical operation or instead with only classical operations.

Attachment:- Script programming and Quantum Computing.rar

Post New Homework
Captcha

Looking tutor’s service for getting help in UK studies or college assignments? Order Now