tone.pl
上传用户:sy_wanhua
上传日期:2013-07-25
资源大小:3048k
文件大小:3k
源码类别:

流媒体/Mpeg4/MP4

开发平台:

C/C++

  1. #!/usr/bin/perl
  2. # ====================================================================
  3. # The Vovida Software License, Version 1.0 
  4. # Copyright (c) 2000 Vovida Networks, Inc.  All rights reserved.
  5. # Redistribution and use in source and binary forms, with or without
  6. # modification, are permitted provided that the following conditions
  7. # are met:
  8. # 1. Redistributions of source code must retain the above copyright
  9. #    notice, this list of conditions and the following disclaimer.
  10. # 2. Redistributions in binary form must reproduce the above copyright
  11. #    notice, this list of conditions and the following disclaimer in
  12. #    the documentation and/or other materials provided with the
  13. #    distribution.
  14. # 3. The names "VOCAL", "Vovida Open Communication Application Library",
  15. #    and "Vovida Open Communication Application Library (VOCAL)" must
  16. #    not be used to endorse or promote products derived from this
  17. #    software without prior written permission. For written
  18. #    permission, please contact vocal@vovida.org.
  19. # 4. Products derived from this software may not be called "VOCAL", nor
  20. #    may "VOCAL" appear in their name, without prior written
  21. #    permission of Vovida Networks, Inc.
  22. # THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED
  23. # WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  24. # OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND
  25. # NON-INFRINGEMENT ARE DISCLAIMED.  IN NO EVENT SHALL VOVIDA
  26. # NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES
  27. # IN EXCESS OF $1,000, NOR FOR ANY INDIRECT, INCIDENTAL, SPECIAL,
  28. # EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  29. # PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  30. # PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
  31. # OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  32. # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
  33. # USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
  34. # DAMAGE.
  35. # ====================================================================
  36. # This software consists of voluntary contributions made by Vovida
  37. # Networks, Inc. and many individuals on behalf of Vovida Networks,
  38. # Inc.  For more information on Vovida Networks, Inc., please see
  39. # <http://www.vovida.org/>.
  40. # build signed linear tone files
  41. # usage:  tone.pl frequency duration
  42. # where frequency is in hertz and duration is in seconds
  43. # this program produces 8Khz samples 8 bit signed samples as its output
  44. # e.g. to convert an output file from this program via sox:
  45. # to convert from raw to wav:
  46. # tone.pl 512 1 > sample.raw 
  47. # sox -traw -r8000 -s -b sample.raw -t wav sample.wav
  48. $freq = $ARGV[0];
  49. $duration = $ARGV[1];
  50. $loudness = $ARGV[2];
  51. print STDERR "frequency: $freqn";
  52. print STDERR "duration: $duration secondsn";
  53. print STDERR "loudness: $loudnessn";
  54. $rate = 8000 ;  # 8000 samples / sec for this s/w
  55. $num_samples = $rate * $duration;
  56. # frequency = cycles / sec, and duration is in seconds -- so the # of
  57. # samples is rate * duration.
  58. # the number of cycles during that time is freq * duration
  59. $PI = 3.14159265;
  60. $TWO_PI = 2.0 * $PI;
  61. $max = 127;
  62. $amplitude = $max * $loudness;
  63. print STDERR "$x, $num_samplesn";
  64. for($x = 0.0 ; $x < $num_samples ; $x++) {
  65.     $place = ($x / $rate * $TWO_PI * $freq);
  66.     $y = sin($place);
  67.     $new_y = int($y * $amplitude + .5);
  68.     print pack ("c", $new_y);
  69. }