Great Deal! Get Instant $10 FREE in Account on First Order + 10% Cashback on Every Order Order Now

https://wiki.cdot.senecacollege.ca/wiki/OPS445_Online_Assignment_1 -- OPS445 Online Assignment 1 Contents 1 Overview 2 Assignment...

1 answer below »
https://wiki.cdot.senecacollege.ca/wiki/OPS445_Online_Assignment_1




--


OPS445 Online Assignment 1








Contents









  • 1
    Overview




  • 2
    Assignment Requirements




    • 2.1
      GitHub Repository




    • 2.2
      Required Files




    • 2.3
      The First Milestone - BB only!!! (Due Oct 07)




    • 2.4
      The Second Milestone (Due Oct 21)




    • 2.5
      The Assignment (Due Nov 4)




    • 2.6
      Assignment Requirements




      • 2.6.1
        Required Modules and Functions




      • 2.6.2
        Coding Standard




      • 2.6.3
        Command Line Argument to be supported




      • 2.6.4
        Documentation




      • 2.6.5
        Authorship Declaration




      • 2.6.6
        Github Commits






    • 2.7
      Tests and Test results




    • 2.8
      Script structure and sample template




      • 2.8.1
        Sample code for the after() function








  • 3
    Rubric




  • 4
    Due Date and Final Submission requirement





Overview


When making back up of data files or log files, it is a very common practice to name the backup directories and/or files based on the date the backup was done. In order to restore or locate the directory/file, we often need to find out the backup date from today's date.


The computational task for this assignment is to design an algorithm and write a python script according to your algorithm with appropriate functions. The script should take a date in the "DD-MM-YYYY" format as well as a number of days, and return the date when that number of days is applied to the date. That is, if the user enters " XXXXXXXXXX" and "7", the script will return " XXXXXXXXXX". Similarly, if the number is a negative number, the script will return a date in the past.



Assignment Requirements



GitHub Repository




  • Your professor will either provide you with a starting repository, or you will be required to create one. If you are asked to create a repository, you will be required to add your professor as an admin user for that repository. **All repositories must be set to private during the initial phase of creation.**


  • Each significant change to your code should have its own commit. This is the standard that most companies will adhere to: version control commits are used to document proof of work, and commit messages are invaluable when issues are being debugged.


  • When making a change to your code, use the following commands to document the commit:
    git commit -am "a sensible message"
    and
    git push. **Please explain the change you made in your commit message.**



Required Files


There are two files that we are providing to you within the assignment repository [clone it to get these files]:




  • assign1.py
    - contains starter code for your assignment. You should commit all of your code to this file.


  • CheckA1.py
    - is a check script that will help you evaluate your assignment. For full marks, your assignment should pass all checks.



The First Milestone - BB only!!! (Due Oct 07)




  • Before you begin programming, it is important to plan your algorithm. Therefore your first task will be to complete and submit an algorithm document. This document should be named
    algorithm_youruserid.txt. This file should be plaintext. The document will contain two sections:



* A description of how the "after()" function works. The "after()" function is provided to you in the assign1.py template. Open the file, and use clear English to describe what line of code does in such a way that a competent programmer could reproduce the code without seeing it firsthand. * You will then apply the same principles to create an algorithm for "before()", and "dbda()".



  • This file will be submitted to Blackboard a week after the assignment goes live, and should be your first priority. The object of the milestone is not to have a 100% perfect algorithm, but to plan ahead and anticipate challenges and issues with the assignment. The milestone will also give your professor an opportunity for feedback.


  • Here is a basic introduction to Algorithm


  • While you are working on the step-by-step instructions, note that there are different numbers of days in each month and some years have 365 days and some years have 366 days.


  • You should also do some research to find out when we started using the Calendar in the current form. (This will pose a limit on the validity of your algorithm.)



The Second Milestone (Due Oct 21)


For the second milestone, you will be asked to have committed the following functions inside the assign1.py file inside your repository:




  • before()


  • leap_year()


  • valid_date()


It's not necessary to submit these functions to Blackboard. If you have pushed the commits correctly, the changes will be visible to your professor.



The Assignment (Due Nov 4)




  • As stated before, your code will be inside the file "assign1.py". The first step will be to clone (or create) the Assignment 1 repository. Further instructions will be provided by your professor. Additional requirements are outlined below.



Assignment Requirements



Required Modules and Functions




Your python script is allowed to import only the
sys
module from the standard library, and only to handle command line arguments.



Based on the algorithm you have designed for this assignment, you should at least have the following three functions defined in your python script (see later section on the purpose of each function) in order to get a passing grade for this assignment:




  • dbda()


  • after()


  • before()


You should also create additional functions to improve the re-usability of your python code by adding the following functions to earn the maximum possible mark for this assignment:




  • days_in_mon()


  • leap_year()


  • valid_date()


  • usage()



Coding Standard


Your python script must follow the following coding guide:




  • PEP-8 -- Style Guide for writing Python Code



Command Line Argument to be supported




  • You are provided with a file called assign1.py.


  • Be sure that this python script has your name and student_id set inside the docstring.


  • Your python script must support two command-line arguments only: the first should be a valid date in DD-MM-YYYY format and the second an integer (negative or positive).


  • If there are no arguments, more than two arguments, or an invalid date, your script should display the correct usage message and exit.



Documentation




  • Please use python's docstring to document your python script (script level documentation) and each of the functions (function level documentation) you created for this assignment. The docstring should describe 'what' the function does, not 'how' it does.


  • Refer to the docstring for after() to get an idea of the function docstrings required.



Authorship Declaration


All your Python code for this assignment must be placed in a


single source python file

. Please complete the declaration

as part of the docstring

in your Python source code file (replace "Student Name" and "Student ID" with your own name and student id respectively).



Github Commits


You will be graded partly on the quality of your Github commits. Professionals generally follow these guidelines:




  • commit their code after every significant change,


  • the code should run without errors after each commit, and


  • every commit has a descriptive commit message.


These guidelines are not always possible, but you will be expected to follow these guidelines as much as possible. Break your problem into smaller pieces, and work iteratively to solve each small problem. Test your code after each small change you make, and address errors as soon as they arise. It will make your life easier!



Tests and Test results


You must name your python 3 script as
assign1.py. The script should accept two command line arguments, the first one is the date in "DD-MM-YYYY" format, and the second one is the number of day from the given date, a positive value indicates the number of days after the given date, and a negative value indicates the number of days before the given date. If the "DD-MM-YYYY" format is broken, your script should give an appropriate error message. Invalid months (>12) or invalid days of month(different for each month), should be detected and give appropriate error messages. For example:





  • python3 assign1.py XXXXXXXXXX
    , and the output should be




XXXXXXXXXX




  • python3 assign1.py XXXXXXXXXX
    , and the output should be




XXXXXXXXXX




  • python3 assign1.py XXXXXXXXXX
    , and the output should be




XXXXXXXXXX




  • python3 assign1.py XXXXXXXXXX
    , and the output should be




XXXXXXXXXX




  • python3 assign1.py XXXXXXXXXX

    , and the output should be




XXXXXXXXXX




  • python3 assign1.py XXXXXXXXXX
    , and the output should be




Error: wrong month entered




  • python3 assign1.py XXXXXXXXXX
    , and the output should be




Error: wrong day entered




  • python3 assign1.py 2018 2
    , and the output should be




Error: wrong date entered

If there is too few or too many command line arguments given, display the proper usage:




  • Usage: assign1.py DD-MM-YYYY N




Script structure and sample template


The following is a brief description of each function:




  • The
    dbda()
    function should be the main function of your script. The dbda() function will take a date in "DD-MM-YYYY" format, a positive or negative integer, and return a date either before or after the given date according to the value of the given integer in the same format. Your dbda() function should delegate the actual calculation of the target date to either the after() function or the before() function.


  • The
    before()
    function will take a date in "DD-MM-YYYY" format and return the date of the previous day in the same format.


  • The
    after()
    function will take a date in "DD-MM-YYYY" format and return the date of the next day in the same format. Next paragraph is a sample python code for the after() function. To earn the maximum possible mark for the assignment, you should modify the sample after() function to make use of the days_in_mon() function.


  • The
    leap_year()
    function will take a year in "YYYY" format, and return True if the given year is a leap year, otherwise return False.


  • The
    valid_date()
    function will take a date in "DD-MM-YYYY" format, and return True if the given date is a valid date, otherwise return False plus an appropriate status message. The valid_date() function should make use of the days_in_mon() function.


  • The
    days_in_mon()
    function will take a year in "YYYY" format, and return a dictionary object which contains the total number of days in each month for the given year. The days_in_mon() function should make use of the leap_year() function.


  • The
    usage()
    function will take no argument and return a string describing the usage of the script.



Sample code for the after() function


# Return the date in DD-MM-YYYY after the given day #  def after(today):     if len(today)!= 10: XXXXXXXXXXreturn ' XXXXXXXXXX'     else: XXXXXXXXXXstr_day, str_month, str_year = today.split('-' XXXXXXXXXXyear = int(str_year XXXXXXXXXXmonth = int(str_month XXXXXXXXXXday = int(str_day XXXXXXXXXXlyear = year% XXXXXXXXXXif lyear == 0: XXXXXXXXXXfeb_max = 29 # this is a leap year XXXXXXXXXXelse: XXXXXXXXXXfeb_max = 28 # this is not a leap year XXXXXXXXXXlyear = year% XXXXXXXXXXif lyear == 0: XXXXXXXXXXfeb_max = 28 # this is not a leap year XXXXXXXXXXlyear = year% XXXXXXXXXXif lyear == 0: XXXXXXXXXXfeb_max = 29 # this is a leap year XXXXXXXXXXtmp_day = day + 1 # next day XXXXXXXXXXmon_max = { 1:31, 2:feb_max, 3:31, 4:30, 5:31, 6:30, 7:31, 8:31, 9:30, 10:31, 11:30, 12:31} XXXXXXXXXXif tmp_day > mon_max[month]: XXXXXXXXXXto_day = tmp_day% mon_max[month] # if tmp_day > this month's max, reset to XXXXXXXXXXtmp_month = month XXXXXXXXXXelse: XXXXXXXXXXto_day = tmp_day XXXXXXXXXXtmp_month = month XXXXXXXXXXif tmp_month > 12: XXXXXXXXXXto_month = XXXXXXXXXXyear = year XXXXXXXXXXelse: XXXXXXXXXXto_month = tmp_month XXXXXXXXXXnext_date = str(to_day).zfill(2)+"-"+str(to_month).zfill(2)+"-"+str(year).zfill XXXXXXXXXXreturn next_date


Rubric












































































Task

Maximum mark

Actual mark

Program Authorship Declaration
5


Program usage

5


after() function

5


before() function

10


dbda() function

10


script level docstring

5


leap_year() function

5


valid_date() function

5


check script results

15


First Milestone
10

Second Milestone
10

github.com repository
15

Total

100



Due Date and Final Submission requirement


Check with your professor for the due date for your section.


Please submit the following files by the due date:




  • your algorithm document, named as 'algorithm_youruserid.txt', to Blackboard. This is your first milestone.


  • your python script, named as 'assign1.py', should be included in your repository, and also
    submitted to Blackboard.


  • the output of the checking script 'CheckA1.py -f -v &>', named as 'a1_output.txt', should be included in your repository.


Answered 6 days After Feb 22, 2023

Solution

Aditi answered on Feb 24 2023
56 Votes
SOLUTION.PDF

Answer To This Question Is Available To Download

Related Questions & Answers

More Questions »

Submit New Assignment

Copy and Paste Your Assignment Here