4/********************************************************************* 
    5 * Software License Agreement (BSD License) 
    7 *  Copyright (c) 2013, University of Colorado, Boulder 
   10 *  Redistribution and use in source and binary forms, with or without 
   11 *  modification, are permitted provided that the following conditions 
   14 *   * Redistributions of source code must retain the above copyright 
   15 *     notice, this list of conditions and the following disclaimer. 
   16 *   * Redistributions in binary form must reproduce the above 
   17 *     copyright notice, this list of conditions and the following 
   18 *     disclaimer in the documentation and/or other materials provided 
   19 *     with the distribution. 
   20 *   * Neither the name of the Univ of CO, Boulder nor the names of its 
   21 *     contributors may be used to endorse or promote products derived 
   22 *     from this software without specific prior written permission. 
   24 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 
   25 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 
   26 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 
   27 *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 
   28 *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 
   30 INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
   31 *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 
   32 *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 
   33 *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 
   34 *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 
   35 *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 
   36 *  POSSIBILITY OF SUCH DAMAGE. 
   37 *********************************************************************/ 
   42from __future__ 
import print_function
 
   50    num_vector = shlex.split(values)
 
   53    for num 
in num_vector:
 
   54        new_num = round(float(num), decimal_places)
 
   55        print(
"Old:", num, 
"New:", new_num)
 
   56        new_vector.append(str(new_num))
 
   58    new = 
" ".join(new_vector)
 
 
   66if __name__ == 
"__main__":
 
   69        input_file = sys.argv[1]
 
   70        output_file = sys.argv[2]
 
   71        decimal_places = int(sys.argv[3])
 
   72        assert len(sys.argv) < 5  
 
   75            "\nUsage: round_collada_numbers.py <input_dae> <output_dae> <decimal places>" 
   77        print(
"Rounds all the numbers to <decimal places> places\n")
 
   80    print(
"\nCollada Number Rounder")
 
   81    print(
"Rounding numbers to", decimal_places, 
"decimal places\n")
 
   83    namespace = 
"http://www.collada.org/2008/03/COLLADASchema" 
   84    dom = etree.parse(input_file)
 
   87    elements = dom.xpath(
"//ns:translate", namespaces={
"ns": namespace})
 
   88    for i 
in range(len(elements)):
 
   89        elements[i].text = 
doRound(elements[i].text, decimal_places)
 
   92    elements = dom.xpath(
"//ns:rotate", namespaces={
"ns": namespace})
 
   93    for i 
in range(len(elements)):
 
   94        elements[i].text = 
doRound(elements[i].text, decimal_places)
 
   97    elements = dom.xpath(
"//ns:min", namespaces={
"ns": namespace})
 
   98    for i 
in range(len(elements)):
 
   99        elements[i].text = 
doRound(elements[i].text, decimal_places)
 
  102    elements = dom.xpath(
"//ns:max", namespaces={
"ns": namespace})
 
  103    for i 
in range(len(elements)):
 
  104        elements[i].text = 
doRound(elements[i].text, decimal_places)
 
  107    elements = dom.xpath(
"//ns:float", namespaces={
"ns": namespace})
 
  108    for i 
in range(len(elements)):
 
  109        elements[i].text = 
doRound(elements[i].text, decimal_places)
 
  112    with open(output_file, 
"wb") 
as f:
 
  113        dom.write(f, encoding=
"utf-8")
 
doRound(values, decimal_places)
 
void print(PropagationDistanceField &pdf, int numX, int numY, int numZ)