Studying program correctness in ProVIDE
In an attempt to better integrate discrete mathematics into the introductory CS curriculum, we implemented ProVIDE, an enhanced integrated development environment (IDE) for Java that enables students to analyze their computer programs (in terms of their correctness) while they are creating them [1]....
Gespeichert in:
Veröffentlicht in: | Proceedings of the 8th annual Conference on Innovation and Technology in Computer Science Education 2003-09, Vol.35 (3), p.262-262 |
---|---|
Hauptverfasser: | , , , , |
Format: | Artikel |
Sprache: | eng |
Online-Zugang: | Volltext |
Tags: |
Tag hinzufügen
Keine Tags, Fügen Sie den ersten Tag hinzu!
|
container_end_page | 262 |
---|---|
container_issue | 3 |
container_start_page | 262 |
container_title | Proceedings of the 8th annual Conference on Innovation and Technology in Computer Science Education |
container_volume | 35 |
creator | Gegg-Harrison, Timothy S. Bunce, Gary R. Ganetzky, Rebecca D. Olson, Christina M. Wilson, Joshua D. |
description | In an attempt to better integrate discrete mathematics into the introductory CS curriculum, we implemented ProVIDE, an enhanced integrated development environment (IDE) for Java that enables students to analyze their computer programs (in terms of their correctness) while they are creating them [1]. The primary goal of the construction of ProVIDE is the seamless integration of analysis with the creation of computer programs. Because the concept of program correctness is generally taught as an activity independent of the programming process, most introductory CS students preceive it is unnecessary and even irrelevant. The concept of contracts, on the other hand, is generally taught as an integral part of the programming process. As such, most introductory CS students have little difficulty understanding the need to establish contracts via preconditions and postconditions.The approach we have taken with ProVIDE is a modified version of the "design by contract" methodology. Rather than asking the student programmer for both a precondition and postcondition for each of his/her methods, ProVIDE asks the student to simply supply a postcondition. ProVIDE then helps the student construct the appropriate precondition by leading him/her through an axiomatic proof of the correctness of the method. Thus, the proof of correctness of the method is a side-effect of the student's need to construct an appropriate precondition.In this demonstration, we will show some examples of method precondition construction (including loop invariant construction) within ProVIDE, including the following squaring algorithms that uses only additions (which highlights the construction of a loop invariant for a single loop) and only increments and decrements (which highlights the construction of loop invariants for both sequential and nested loops), respectively. |
doi_str_mv | 10.1145/961290.961624 |
format | Article |
fullrecord | <record><control><sourceid>proquest_cross</sourceid><recordid>TN_cdi_crossref_primary_10_1145_961290_961624</recordid><sourceformat>XML</sourceformat><sourcesystem>PC</sourcesystem><sourcerecordid>29497820</sourcerecordid><originalsourceid>FETCH-LOGICAL-c690-86139dc8def873e1a2dc1b5d6ac30acafffff1d7c35766a8de8c36b761eac9b53</originalsourceid><addsrcrecordid>eNotkDtPwzAUhS0BEm1hZM8EU4qvnfgxotJCpUqtRMVqOddOFZRHsZOh_55U4Sxn-XTv0UfIE9AlQJa_agFM0-VYgmU3ZA65AuBCMnZLZpRqmaoM1D2Zx_hDKZNCZDPy8tUP7lK1p-QculOwTYJdCB771seYVG1yCN339n39QO5KW0f_-N8Lctysj6vPdLf_2K7edikKTVMlgGuHyvlSSe7BModQ5E5Y5NSiLa8BJ5Hn43s7cgq5KKQAb1EXOV-Q5-nsuOZ38LE3TRXR17VtfTdEw3SmpWJ0BNMJxNDFGHxpzqFqbLgYoOaqw0w6zKSD_wFMgVHm</addsrcrecordid><sourcetype>Aggregation Database</sourcetype><iscdi>true</iscdi><recordtype>article</recordtype><pqid>29497820</pqid></control><display><type>article</type><title>Studying program correctness in ProVIDE</title><source>ACM Digital Library Complete</source><creator>Gegg-Harrison, Timothy S. ; Bunce, Gary R. ; Ganetzky, Rebecca D. ; Olson, Christina M. ; Wilson, Joshua D.</creator><creatorcontrib>Gegg-Harrison, Timothy S. ; Bunce, Gary R. ; Ganetzky, Rebecca D. ; Olson, Christina M. ; Wilson, Joshua D.</creatorcontrib><description>In an attempt to better integrate discrete mathematics into the introductory CS curriculum, we implemented ProVIDE, an enhanced integrated development environment (IDE) for Java that enables students to analyze their computer programs (in terms of their correctness) while they are creating them [1]. The primary goal of the construction of ProVIDE is the seamless integration of analysis with the creation of computer programs. Because the concept of program correctness is generally taught as an activity independent of the programming process, most introductory CS students preceive it is unnecessary and even irrelevant. The concept of contracts, on the other hand, is generally taught as an integral part of the programming process. As such, most introductory CS students have little difficulty understanding the need to establish contracts via preconditions and postconditions.The approach we have taken with ProVIDE is a modified version of the "design by contract" methodology. Rather than asking the student programmer for both a precondition and postcondition for each of his/her methods, ProVIDE asks the student to simply supply a postcondition. ProVIDE then helps the student construct the appropriate precondition by leading him/her through an axiomatic proof of the correctness of the method. Thus, the proof of correctness of the method is a side-effect of the student's need to construct an appropriate precondition.In this demonstration, we will show some examples of method precondition construction (including loop invariant construction) within ProVIDE, including the following squaring algorithms that uses only additions (which highlights the construction of a loop invariant for a single loop) and only increments and decrements (which highlights the construction of loop invariants for both sequential and nested loops), respectively.</description><identifier>ISSN: 0097-8418</identifier><identifier>ISBN: 1581136722</identifier><identifier>ISBN: 9781581136722</identifier><identifier>DOI: 10.1145/961290.961624</identifier><language>eng</language><ispartof>Proceedings of the 8th annual Conference on Innovation and Technology in Computer Science Education, 2003-09, Vol.35 (3), p.262-262</ispartof><woscitedreferencessubscribed>false</woscitedreferencessubscribed><cites>FETCH-LOGICAL-c690-86139dc8def873e1a2dc1b5d6ac30acafffff1d7c35766a8de8c36b761eac9b53</cites></display><links><openurl>$$Topenurl_article</openurl><openurlfulltext>$$Topenurlfull_article</openurlfulltext><thumbnail>$$Tsyndetics_thumb_exl</thumbnail><link.rule.ids>314,776,780,27903,27904</link.rule.ids></links><search><creatorcontrib>Gegg-Harrison, Timothy S.</creatorcontrib><creatorcontrib>Bunce, Gary R.</creatorcontrib><creatorcontrib>Ganetzky, Rebecca D.</creatorcontrib><creatorcontrib>Olson, Christina M.</creatorcontrib><creatorcontrib>Wilson, Joshua D.</creatorcontrib><title>Studying program correctness in ProVIDE</title><title>Proceedings of the 8th annual Conference on Innovation and Technology in Computer Science Education</title><description>In an attempt to better integrate discrete mathematics into the introductory CS curriculum, we implemented ProVIDE, an enhanced integrated development environment (IDE) for Java that enables students to analyze their computer programs (in terms of their correctness) while they are creating them [1]. The primary goal of the construction of ProVIDE is the seamless integration of analysis with the creation of computer programs. Because the concept of program correctness is generally taught as an activity independent of the programming process, most introductory CS students preceive it is unnecessary and even irrelevant. The concept of contracts, on the other hand, is generally taught as an integral part of the programming process. As such, most introductory CS students have little difficulty understanding the need to establish contracts via preconditions and postconditions.The approach we have taken with ProVIDE is a modified version of the "design by contract" methodology. Rather than asking the student programmer for both a precondition and postcondition for each of his/her methods, ProVIDE asks the student to simply supply a postcondition. ProVIDE then helps the student construct the appropriate precondition by leading him/her through an axiomatic proof of the correctness of the method. Thus, the proof of correctness of the method is a side-effect of the student's need to construct an appropriate precondition.In this demonstration, we will show some examples of method precondition construction (including loop invariant construction) within ProVIDE, including the following squaring algorithms that uses only additions (which highlights the construction of a loop invariant for a single loop) and only increments and decrements (which highlights the construction of loop invariants for both sequential and nested loops), respectively.</description><issn>0097-8418</issn><isbn>1581136722</isbn><isbn>9781581136722</isbn><fulltext>true</fulltext><rsrctype>article</rsrctype><creationdate>2003</creationdate><recordtype>article</recordtype><recordid>eNotkDtPwzAUhS0BEm1hZM8EU4qvnfgxotJCpUqtRMVqOddOFZRHsZOh_55U4Sxn-XTv0UfIE9AlQJa_agFM0-VYgmU3ZA65AuBCMnZLZpRqmaoM1D2Zx_hDKZNCZDPy8tUP7lK1p-QculOwTYJdCB771seYVG1yCN339n39QO5KW0f_-N8Lctysj6vPdLf_2K7edikKTVMlgGuHyvlSSe7BModQ5E5Y5NSiLa8BJ5Hn43s7cgq5KKQAb1EXOV-Q5-nsuOZ38LE3TRXR17VtfTdEw3SmpWJ0BNMJxNDFGHxpzqFqbLgYoOaqw0w6zKSD_wFMgVHm</recordid><startdate>200309</startdate><enddate>200309</enddate><creator>Gegg-Harrison, Timothy S.</creator><creator>Bunce, Gary R.</creator><creator>Ganetzky, Rebecca D.</creator><creator>Olson, Christina M.</creator><creator>Wilson, Joshua D.</creator><scope>AAYXX</scope><scope>CITATION</scope><scope>7SC</scope><scope>8FD</scope><scope>JQ2</scope><scope>L7M</scope><scope>L~C</scope><scope>L~D</scope></search><sort><creationdate>200309</creationdate><title>Studying program correctness in ProVIDE</title><author>Gegg-Harrison, Timothy S. ; Bunce, Gary R. ; Ganetzky, Rebecca D. ; Olson, Christina M. ; Wilson, Joshua D.</author></sort><facets><frbrtype>5</frbrtype><frbrgroupid>cdi_FETCH-LOGICAL-c690-86139dc8def873e1a2dc1b5d6ac30acafffff1d7c35766a8de8c36b761eac9b53</frbrgroupid><rsrctype>articles</rsrctype><prefilter>articles</prefilter><language>eng</language><creationdate>2003</creationdate><toplevel>online_resources</toplevel><creatorcontrib>Gegg-Harrison, Timothy S.</creatorcontrib><creatorcontrib>Bunce, Gary R.</creatorcontrib><creatorcontrib>Ganetzky, Rebecca D.</creatorcontrib><creatorcontrib>Olson, Christina M.</creatorcontrib><creatorcontrib>Wilson, Joshua D.</creatorcontrib><collection>CrossRef</collection><collection>Computer and Information Systems Abstracts</collection><collection>Technology Research Database</collection><collection>ProQuest Computer Science Collection</collection><collection>Advanced Technologies Database with Aerospace</collection><collection>Computer and Information Systems Abstracts Academic</collection><collection>Computer and Information Systems Abstracts Professional</collection><jtitle>Proceedings of the 8th annual Conference on Innovation and Technology in Computer Science Education</jtitle></facets><delivery><delcategory>Remote Search Resource</delcategory><fulltext>fulltext</fulltext></delivery><addata><au>Gegg-Harrison, Timothy S.</au><au>Bunce, Gary R.</au><au>Ganetzky, Rebecca D.</au><au>Olson, Christina M.</au><au>Wilson, Joshua D.</au><format>journal</format><genre>article</genre><ristype>JOUR</ristype><atitle>Studying program correctness in ProVIDE</atitle><jtitle>Proceedings of the 8th annual Conference on Innovation and Technology in Computer Science Education</jtitle><date>2003-09</date><risdate>2003</risdate><volume>35</volume><issue>3</issue><spage>262</spage><epage>262</epage><pages>262-262</pages><issn>0097-8418</issn><isbn>1581136722</isbn><isbn>9781581136722</isbn><abstract>In an attempt to better integrate discrete mathematics into the introductory CS curriculum, we implemented ProVIDE, an enhanced integrated development environment (IDE) for Java that enables students to analyze their computer programs (in terms of their correctness) while they are creating them [1]. The primary goal of the construction of ProVIDE is the seamless integration of analysis with the creation of computer programs. Because the concept of program correctness is generally taught as an activity independent of the programming process, most introductory CS students preceive it is unnecessary and even irrelevant. The concept of contracts, on the other hand, is generally taught as an integral part of the programming process. As such, most introductory CS students have little difficulty understanding the need to establish contracts via preconditions and postconditions.The approach we have taken with ProVIDE is a modified version of the "design by contract" methodology. Rather than asking the student programmer for both a precondition and postcondition for each of his/her methods, ProVIDE asks the student to simply supply a postcondition. ProVIDE then helps the student construct the appropriate precondition by leading him/her through an axiomatic proof of the correctness of the method. Thus, the proof of correctness of the method is a side-effect of the student's need to construct an appropriate precondition.In this demonstration, we will show some examples of method precondition construction (including loop invariant construction) within ProVIDE, including the following squaring algorithms that uses only additions (which highlights the construction of a loop invariant for a single loop) and only increments and decrements (which highlights the construction of loop invariants for both sequential and nested loops), respectively.</abstract><doi>10.1145/961290.961624</doi><tpages>1</tpages></addata></record> |
fulltext | fulltext |
identifier | ISSN: 0097-8418 |
ispartof | Proceedings of the 8th annual Conference on Innovation and Technology in Computer Science Education, 2003-09, Vol.35 (3), p.262-262 |
issn | 0097-8418 |
language | eng |
recordid | cdi_crossref_primary_10_1145_961290_961624 |
source | ACM Digital Library Complete |
title | Studying program correctness in ProVIDE |
url | https://sfx.bib-bvb.de/sfx_tum?ctx_ver=Z39.88-2004&ctx_enc=info:ofi/enc:UTF-8&ctx_tim=2025-01-22T03%3A16%3A20IST&url_ver=Z39.88-2004&url_ctx_fmt=infofi/fmt:kev:mtx:ctx&rfr_id=info:sid/primo.exlibrisgroup.com:primo3-Article-proquest_cross&rft_val_fmt=info:ofi/fmt:kev:mtx:journal&rft.genre=article&rft.atitle=Studying%20program%20correctness%20in%20ProVIDE&rft.jtitle=Proceedings%20of%20the%208th%20annual%20Conference%20on%20Innovation%20and%20Technology%20in%20Computer%20Science%20Education&rft.au=Gegg-Harrison,%20Timothy%20S.&rft.date=2003-09&rft.volume=35&rft.issue=3&rft.spage=262&rft.epage=262&rft.pages=262-262&rft.issn=0097-8418&rft.isbn=1581136722&rft.isbn_list=9781581136722&rft_id=info:doi/10.1145/961290.961624&rft_dat=%3Cproquest_cross%3E29497820%3C/proquest_cross%3E%3Curl%3E%3C/url%3E&disable_directlink=true&sfx.directlink=off&sfx.report_link=0&rft_id=info:oai/&rft_pqid=29497820&rft_id=info:pmid/&rfr_iscdi=true |