Difference between revisions of "ExtractingCoordinatesFromPoint"

From WeBWorK_wiki
Jump to navigation Jump to search
m
(added historical tag and gave updated problem link)
 
(One intermediate revision by one other user not shown)
Line 1: Line 1:
  +
{{historical}}
  +
  +
<p style="font-size: 120%;font-weight:bold">This problem has been replaced with [https://openwebwork.github.io/pg-docs/sample-problems/problem-techniques/ExtractingCoordinatesFromPoint.html a newer version of this problem]</p>
 
<h2>Extracting coordinates from a Point: PG Code Snippet</h2>
 
<h2>Extracting coordinates from a Point: PG Code Snippet</h2>
   
Line 83: Line 86:
   
 
BEGIN_TEXT
 
BEGIN_TEXT
Consider the two points \( $point[0] \) and \( $point[1] \).
+
Consider the two points \( $point[0] \)
The distance between them is:\{ $length->ans_rule() \}
+
and \( $point[1] \).
  +
The distance between them is:
  +
\{ $length->ans_rule() \}
 
$BR
 
$BR
 
The midpoint of the line segment
 
The midpoint of the line segment

Latest revision as of 08:42, 28 June 2023

This article has been retained as a historical document. It is not up-to-date and the formatting may be lacking. Use the information herein with caution.

This problem has been replaced with a newer version of this problem

Extracting coordinates from a Point: PG Code Snippet


This code snippet shows the essential PG code to evaluate antderivative and general antiderivative formulas. Note that these are insertions, not a complete PG file. This code will have to be incorporated into the problem file on which you are working.

This wiki page is under construction as of 6/13/08.

Problem Techniques Index

PG problem file Explanation
loadMacros("MathObjects.pl");

In the initialization section, we need to include the macros file MathObjects.pl.

Context( "Point" );

push(@point, Point(random(1,5,1), random(-5,-1,1)));
push(@point, Point(random(5,10,1), random(6,11,1)));

# now we have two points, $point[0] = (x1,y1)
# and $point[1] = (x2,y2).
# the following makes $d1 = x1 - x2, $d2 = y1 - y2
($d1, $d2) = ($point[0] - $point[1])->value;


$length = Compute("sqrt( ($d1)^2+($d2)^2 )");
$mid = ( $point[1] + $point[0] ) / 2;

In the problem setup section of the file, we put the value of the subtraction of two Points in two variables, $d1, the x coordinate, and $d2, the y coordinate. This is achieved by calling Point's value method, as shown.

Alternative method: If you want to get only one of the coordinates of a Point, you can use the extract method, for example: $x = $point->extract(1);. This gets the first coordinate of $point (x) and assigns it to the variable $x.

We don't use Context("Vector"); and norm( $point[0] - $point[1] ) here to determine length because we don't want to accept an answer like |<5,7>-<7,8>|.

Alternative method: You can use $length=norm( $point[0] - $point[1] ); with Context("Vector"); if you want to accept answers that are valid in the Vector context (such as the absolute value of a vector).

We need to put parentheses around $d1 and $d2 in the Compute expression because if $d1 = -6, then -6^2 = -36, not 36, as desired. However, if the code is ($d1)^2 then that evaluates as (-6)^2 = 36, as desired.

Context()->texStrings;

BEGIN_TEXT
Consider the two points \( $point[0] \)
and \( $point[1] \).
The distance between them is:
\{ $length->ans_rule() \}
$BR
The midpoint of the line segment
that joins them is:\{ $mid->ans_rule() \}
$BR
END_TEXT

Context()->normalStrings;

The problem text section of the file is as we'd expect.

ANS( $length->cmp );
ANS( $mid->cmp );

As is the answer.

Problem Techniques Index