/************************************************************************** *** *** Copyright (c) 2004 Regents of the University of Michigan, *** Hayward H. Chan and Igor L. Markov *** *** Contact author(s): hhchan@umich.edu, imarkov@umich.edu *** Original Affiliation: EECS Department, *** The University of Michigan, *** Ann Arbor, MI 48109-2122 *** *** Permission is hereby granted, free of charge, to any person obtaining *** a copy of this software and associated documentation files (the *** "Software"), to deal in the Software without restriction, including *** without limitation *** the rights to use, copy, modify, merge, publish, distribute, sublicense, *** and/or sell copies of the Software, and to permit persons to whom the *** Software is furnished to do so, subject to the following conditions: *** *** The above copyright notice and this permission notice shall be included *** in all copies or substantial portions of the Software. *** *** THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, *** EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES *** OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. *** IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY *** CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT *** OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR *** THE USE OR OTHER DEALINGS IN THE SOFTWARE. *** *** ***************************************************************************/ #include #include #include #include using namespace std; int main(int argc, char *argv[]) { ifstream infile; ofstream outfile; infile.open(argv[1]); if (!infile.good()) { cout << "ERROR: cannot open file: " << argv[1] << endl; exit(1); } outfile.open(argv[2]); if (!outfile.good()) { cout << "ERROR: cannot open file: " << argv[2] << endl; exit(1); } double maxAR = atof(argv[3]); int blocknum; infile >> blocknum; infile.ignore(100, '\n'); outfile << blocknum << endl; for (int i = 0; i < blocknum; i++) { string line; getline(infile, line); double area = -1; stringstream lineStream(line); lineStream >> area; double AR_low = min(maxAR, 1/maxAR); double AR_high = max(maxAR, 1/maxAR); outfile << area << " " << AR_low << " " << AR_high << endl; } infile.close(); outfile.close(); return 0; }