source:
plugins/audacity/audacity-nyquist.diff
@
01b8fcc
Last change on this file since 01b8fcc was 96fb8ad, checked in by , 20 years ago | |
---|---|
|
|
File size: 22.3 KB |
-
nyquist/misc.lsp
old new 74 74 (setf fullpath ":"))) 75 75 fullpath) 76 76 (t nil)))) 77 78 ;; real-random -- pick a random real from a range79 ;;80 (defun real-random (from to)81 (cond ((= from to) from)82 (t83 (+ from84 (* (random 10000)85 0.000186 (- to from))))))87 88 ;; power -- raise a number to some power x^y89 ;;90 (defun power (x y)91 (exp (* (log (float x)) y)))92 -
nyquist/nyinit.lsp
old new 26 26 (setf *WATCH* NIL) 27 27 28 28 (format t "~%Nyquist -- A Language for Sound Synthesis and Composition~%") 29 (format t " Copyright (c) 1991 -2003by Roger B. Dannenberg~%")29 (format t " Copyright (c) 1991,1992,1995 by Roger B. Dannenberg~%") 30 30 (format t " Version 2.29~%~%") 31 31 32 32 (setf *gc-flag* t) -
nyquist/nyquist.lsp
old new 6 6 ;;; ########################################################### 7 7 ;;; 8 8 9 ;;; 10 ;;; Modifications for using Nyquist within Audacity 11 ;;; by Dominic Mazzoni 12 ;;; 9 (load "fileio.lsp") 13 10 14 11 (prog () 15 12 (setq lppp -12.0) (setq lpp -9.0) (setq lp -6.0) (setq lmp -3.0) … … 217 214 (cond ((> hz (/ *SOUND-SRATE* 2)) 218 215 (format t "Warning: buzz nominal frequency (~A hz) will alias at current sample rate (~A hz).\n" 219 216 hz *SOUND-SRATE*))) 220 (setf n (m inn 1)) ; avoid divide by zero problem217 (setf n (max n 1)) ; avoid divide by zero problem 221 218 (scale-db (get-loud) 222 219 (snd-buzz n ; number of harmonics 223 220 *SOUND-SRATE* ; output sample rate … … 344 341 d ; duration 345 342 phase))) ; phase 346 343 344 347 345 ;; FMLFO -- like LFO but uses frequency modulation 348 346 ;; 349 347 (defun fmlfo (freq &optional (sound *SINE-TABLE*) (phase 0.0)) … … 358 356 (t 359 357 (error "frequency must be a number or sound"))))) 360 358 359 361 360 ;; OSC - table lookup oscillator 362 361 ;; 363 362 (defun osc (pitch &optional (duration 1.0) … … 761 760 ,s)) 762 761 763 762 763 ;; COMPUTE-DEFAULT-SOUND-FILE -- construct and set *default-sound-file* 764 ;; 765 ;; (this is harder than it might seem because the default place for 766 ;; sound files is in /tmp, which is shared by users, so we'd like to 767 ;; use a user-specific name to avoid collisions) 768 ;; 769 (defun compute-default-sound-file () 770 (let (inf user extension) 771 ; the reason for the user name is that if UserA creates a temp file, 772 ; then UserB will not be able to overwrite it. The user name is a 773 ; way to give each user a unique temp file name. Note that we don't 774 ; want each session to generate a unique name because Nyquist doesn't 775 ; delete the sound file at the end of the session. 776 (system "echo $USER > ny_username.tmp") 777 (setf inf (open "ny_username.tmp")) 778 (cond (inf 779 (setf user (read inf)) 780 (close inf) 781 (system "rm ny_username.tmp")) 782 (t ; must not be unix, make up a generic name 783 (setf user 'nyquist))) 784 (cond ((null user) 785 (format t 786 "Please type your user-id so that I can construct a default 787 sound-file name. To avoid this message in the future, add 788 this to your .login file: 789 setenv USER <your id here> 790 or add this to your init.lsp file: 791 (setf *default-sound-file* \"<your filename here>\") 792 (setf *default-sf-dir* \"<full pathname of desired directory here>\") 793 794 Your id please: ") 795 (setf user (read)))) 796 ; now compute the extension based on *default-sf-format* 797 (cond ((= *default-sf-format* snd-head-AIFF) 798 (setf extension ".aif")) 799 ((= *default-sf-format* snd-head-Wave) 800 (setf extension ".wav")) 801 (t 802 (setf extension ".snd"))) 803 (setf *default-sound-file* 804 (strcat (string-downcase (symbol-name user)) "-temp" extension)) 805 (format t "Default sound file is ~A.~%" *default-sound-file*))) 806 807 764 808 ;; CONTROL-WARP -- apply a warp function to a control function 765 809 ;; 766 810 (defun control-warp (warp-fn control &optional wrate) … … 792 836 (snd-srate sound) 793 837 (local-to-global 0) *START* *STOP* (db-to-linear (get-loud)))) 794 838 839 ; (s-plot (progv '(*TIME* *START*)'(0.0 0.5)(cue (snd-sine 20 1 100 1)))1000) 840 ;(s-plot(progv'(*TIME* *START*)'(0.0 0.5)(cue(cue (snd-sine 20 1 100 1))))1000) 841 795 842 ;; (sound sound) 796 843 ;; Same as (cue sound), except also warps the sound. 797 844 ;; Note that the *WARP* can change the pitch of the … … 861 908 (setfn control sound) 862 909 863 910 911 ;; (cue-file string) 912 ;; Loads a sound file with the given name, returning a sound which is 913 ;; transformed to the current environment. 914 ;(defun cue-file (name) 915 ; (cue (snd-load name *SOUND-SRATE*))) 916 917 864 918 ;; (env t1 t2 t4 l1 l2 l3 &optional duration) 865 919 ;; Creates a 4-phase envelope. 866 920 ;; tN is the duration of phase N, and lN is the final level of … … 1327 1381 ; 1328 1382 (load "seq" :verbose NIL) 1329 1383 1384 ;(defmacro with%environment (env &rest expr) 1385 ; `(progv ',*environment-variables* ',env ,@expr)) 1386 ; 1387 ;(defmacro seq (&rest list) 1388 ; (display "seq" list) 1389 ; (cond ((null list) 1390 ; (snd-zero *time* *sound-srate*)) 1391 ; ((null (cdr list)) 1392 ; (car list)) 1393 ; ((null (cddr list)) 1394 ; `(let* ((first%sound ,(car list)) 1395 ; (s%rate (snd-srate first%sound))) 1396 ; (snd-seq first%sound 1397 ; #'(lambda (t0) 1398 ; (with%environment 1399 ; ,(the%environment) (setf *time* t0) 1400 ; (force-srate s%rate ,(cadr list))))))) 1401 ; (t 1402 ; `(let* ((first%sound ,(car list)) 1403 ; (s%rate (snd-srate first%sound))) 1404 ; (snd-seq first%sound 1405 ; #'(lambda (t0) 1406 ; (format t "snd-seq applying lambda") 1407 ; (with%environment 1408 ; ,(the%environment) (setf *time* t0) 1409 ; (seq (force-srate s%rate ,(cadr list)) 1410 ; ,@(cddr list))))) )))) 1411 ; 1412 ; 1413 ;(defmacro seqrep (pair sound) 1414 ; `(let ((,(car pair) 0) 1415 ; ($loop-count (1- ,(cadr pair)))) 1416 ; (cond ((< 0 $loop-count) 1417 ; (seqrep2 ,(car pair) ,sound)) 1418 ; ((= 0 $loop-count) 1419 ; ,sound) 1420 ; (t 1421 ; (snd-zero *time* *sound-srate*))))) 1422 ; 1423 ; 1424 ;(defmacro seqrep2 (var sound) 1425 ; `(cond ((< ,var $loop-count) 1426 ; (seq (prog1 ,sound (setf ,var (1+ ,var))) 1427 ; (seqrep2 ,var ,sound))) 1428 ; ((= ,var $loop-count) 1429 ; ,sound))) 1430 1431 1330 1432 ; set-logical-stop - modify the sound and return it, time is shifted and 1331 1433 ; stretched 1332 1434 (defun set-logical-stop (snd tim) … … 1532 1634 (defun osc-pulse (hz bias &optional (compare-shape *step-shape*)) 1533 1635 (compare bias (osc-tri hz) compare-shape)) 1534 1636 1535 (setf NY:ALL 1000000000) 1637 -
nyquist/seq.lsp
old new 176 176 (error (format nil "Negative stretch factor in TIMED-SEQ: ~A" event))) 177 177 (t 178 178 (setf start-time (car event))))) 179 (cond ((null score) (s-rest 0)) 180 (t 181 (at (caar score) 182 (seqrep (i (length score)) 183 (cond ((cdr score) 184 (let (event) 185 (prog1 186 (set-logical-stop 187 (stretch (cadar score) 188 (setf event (eval (caddar score)))) 189 (- (caadr score) (caar score))) 190 ; (display "timed-seq" (caddar score) (local-to-global 0)) 191 (setf score (cdr score))))) 192 (t 193 (stretch (cadar score) (eval (caddar score))))))))))) 179 (at (caar score) 180 (seqrep (i (length score)) 181 (cond ((cdr score) 182 (let (event) 183 (prog1 184 (set-logical-stop (stretch (cadar score) 185 (setf event (eval (caddar score)))) 186 (- (caadr score) (caar score))) 187 ; (display "timed-seq" (caddar score) (local-to-global 0)) 188 (setf score (cdr score))))) 189 (t 190 (stretch (cadar score) (eval (caddar score))))))))) 194 191 195 192 196 193 -
nyquist/system.lsp
old new 1 ; system.lsp -- machine/system-dependent definitions1 ;; system.lsp -- system-dependent lisp code 2 2 3 ;; default behavior is to call SETUP-CONSOLE to get large white typescript 4 ;; 5 ;; set *setup-console* to nil in your personal init.lsp to override this behavior 6 ;; (this may be necessary to work with emacs) 7 ;; 8 (if (not (boundp '*setup-console*)) (setf *setup-console* t)) 9 (if *setup-console* (setup-console)) 3 ; local definition for play 4 ; this one is for Linux: 10 5 11 6 (setf ny:bigendianp nil) 12 7 13 8 (if (not (boundp '*default-sf-format*)) 14 (setf *default-sf-format* snd-head- Wave))9 (setf *default-sf-format* snd-head-wave)) 15 10 16 ;(if (not (boundp '*default-sound-file*))17 ; (setf *default-sound-file* "temp.wav"))11 (if (not (boundp '*default-sound-file*)) 12 (compute-default-sound-file)) 18 13 19 ;(if (not (boundp '*default-sf-dir*))20 ; (setf *default-sf-dir* ""))14 (if (not (boundp '*default-sf-dir*)) 15 (setf *default-sf-dir* "./")) 21 16 22 17 (if (not (boundp '*default-sf-mode*)) 23 18 (setf *default-sf-mode* snd-head-mode-pcm)) … … 25 20 (if (not (boundp '*default-sf-bits*)) 26 21 (setf *default-sf-bits* 16)) 27 22 28 ;(if (not (boundp '*default-plot-file*)) 29 ; (setf *default-plot-file* "points.dat")) 30 31 ;(if (not (boundp '*plotscript-file*)) 32 ; (setf *plotscript-file* "sys/unix/rs6k/plotscript")) 33 34 ; local definition for play 35 ;(defmacro play (expr) 36 ; `(s-save-autonorm ,expr NY:ALL *default-sound-file* :play *soundenable*)) 37 38 39 ;(defun r () 40 ; (s-save (s-read *default-sound-file*) NY:ALL "" :play t) 41 ;) 42 43 44 ; PLAY-FILE -- play a file 45 ;(defun play-file (name) 46 ; (s-save (s-read name) NY:ALL "" :play t)) 23 (if (not (boundp '*default-plot-file*)) 24 (setf *default-plot-file* "points.dat")) 47 25 48 26 49 27 ; FULL-NAME-P -- test if file name is a full path or relative path … … 51 29 ; (otherwise the *default-sf-dir* will be prepended 52 30 ; 53 31 (defun full-name-p (filename) 54 (or (eq (char filename 0) #\\) 55 (eq (char filename 0) #\.) 56 (and (> (length filename) 2) 57 (both-case-p (char filename 0)) 58 (equal (char filename 1) #\:)))) 32 (or (eq (char filename 0) #\/) 33 (eq (char filename 0) #\.))) 59 34 60 (setf *file-separator* #\\)61 35 62 ;(defun ny:load-file () (load "*.*")) 63 ;(defun ny:reload-file () (load "*")) 36 (setf *file-separator* #\/) 64 37 65 38 66 ; save the standard function to write points to a file 67 ; 68 ;(setfn s-plot-points s-plot) 39 ;; PLAY-FILE - play a sound file 40 ;; 41 (defun play-file (name) 42 ;; (system (strcat "sndplay " (soundfilename name)))) 43 (system (strcat "play " (soundfilename name) ))) 44 45 ;; R - replay last file written with PLAY 46 (defun r () (play-file *default-sound-file*)) 47 48 ;;;; use this old version if you want to use sndplay to play 49 ;;;; the result file rather than play the samples as they 50 ;;;; are computed. This version does not autonormalize. 51 ;; PLAY - write value of an expression to file and play it 52 ;; 53 ;(defmacro play (expr) 54 ; `(prog (specs) 55 ; (setf specs (s-save (force-srate *sound-srate* ,expr) 56 ; 1000000000 *default-sound-file*)) 57 ; (r))) 58 ;;;; 69 59 70 ;(defun array-max-abs (points) 71 ; (let ((m 0.0)) 72 ; (dotimes (i (length points)) 73 ; (setf m (max m (abs (aref points i))))) 74 ; m)) 75 76 ;(setf graph-width 600) 77 ;(setf graph-height 220) 78 79 ;(defun s-plot (snd &optional (n 600)) 80 ; (show-graphics) 81 ; (clear-graphics) 82 ; (cond ((soundp snd) 83 ; (s-plot-2 snd n (/ graph-height 2) graph-height)) 84 ; (t 85 ; (let ((gh (/ graph-height (length snd))) 86 ; hs) 87 ; (dotimes (i (length snd)) 88 ; (setf hs (s-plot-2 (aref snd i) n (+ (/ gh 2) (* i gh)) gh hs))))))) 89 ; 90 ; 91 ;(defun s-plot-2 (snd n y-offset graph-height horizontal-scale) 92 ; (prog ((points (snd-samples snd n)) 93 ; maxpoint horizontal-scale vertical-scale) 94 ; (setf maxpoint (array-max-abs points)) 95 ; (moveto 0 y-offset) 96 ; (lineto graph-width y-offset) 97 ; (moveto 0 y-offset) 98 ; (cond ((null horizontal-scale) 99 ; (setf horizontal-scale (/ (float graph-width) (length points))))) 100 ; (setf vertical-scale (- (/ (float graph-height) 2 maxpoint))) 101 ; (dotimes (i (length points)) 102 ; (lineto (truncate (* horizontal-scale i)) 103 ; (+ y-offset (truncate (* vertical-scale (aref points i)))))) 104 ; (format t "X Axis: ~A to ~A (seconds)\n" (snd-t0 snd) (/ (length points) (snd-srate snd))) 105 ; (format t "Y Axis: ~A to ~A\n" (- maxpoint) maxpoint) 106 ; (format t "~A samples plotted.\n" (length points)) 107 ; (return horizontal-scale) 108 ; )) 109 ; 110 ; S-EDIT - run the audio editor on a sound 111 ; 112 ;(defmacro s-edit (&optional expr) 113 ; `(prog () 114 ; (if ,expr (s-save ,expr 1000000000 *default-sound-file*)) 115 ; (system (format nil "audio_editor ~A &" 116 ; (soundfilename *default-sound-file*))))) 60 ; local definition for play 61 (defmacro play (expr) 62 `(s-save-autonorm ,expr NY:ALL *default-sound-file* :play *soundenable*)) 63 64 ;; for Linux, modify s-plot (defined in nyquist.lsp) by saving s-plot 65 ;; in standard-s-plot, then call gnuplot to display the points. 66 ;; 67 ;; we also need to save the location of this file so we can find 68 ;; nyquist-plot.txt, the command file for gnuplot 69 ;; 70 (setf *runtime-path* (current-path)) 71 (display "system.lsp" *runtime-path*) 72 73 (setfn standard-s-plot s-plot) 74 75 (defun s-plot (s) 76 (let (plot-file) 77 (standard-s-plot s) ;; this calculates the data points 78 (setf plot-file (strcat *runtime-path* "nyquist-plot.txt")) 79 (system (strcat "gnuplot -persist " plot-file)))) 117 80 -
nyquist/fileio.lsp
old new 1 ;; s-save -- saves a file 2 (setf NY:ALL 1000000000) ; 1GIG constant for maxlen 3 (defmacro s-save (expression &optional (maxlen NY:ALL) filename 4 &key (format '*default-sf-format*) 5 (mode '*default-sf-mode*) (bits '*default-sf-bits*) 6 (endian NIL) ; nil, :big, or :little -- specifies file format 7 (play nil)) 8 `(let ((ny:fname ,filename) 9 (ny:maxlen ,maxlen) 10 (ny:endian ,endian) 11 (ny:swap 0)) 12 ; allow caller to omit maxlen, in which case the filename will 13 ; be a string in the maxlen parameter position and filename will be null 14 (cond ((null ny:fname) 15 (cond ((stringp ny:maxlen) 16 (setf ny:fname ny:maxlen) 17 (setf ny:maxlen NY:ALL)) 18 (t 19 (setf ny:fname *default-sound-file*))))) 20 21 (cond ((equal ny:fname "") 22 (cond ((not ,play) 23 (format t "s-save: no file to write! play option is off!\n")))) 24 (t 25 (setf ny:fname (soundfilename ny:fname)) 26 (format t "Saving sound file to ~A~%" ny:fname))) 27 (cond ((eq ny:endian :big) 28 (setf ny:swap (if ny:bigendianp 0 1))) 29 ((eq ny:endian :little) 30 (setf ny:swap (if ny:bigendianp 1 0)))) 31 (snd-save ',expression ny:maxlen ny:fname ,format ,mode ,bits ny:swap ,play))) 32 33 (defmacro s-save-autonorm (expression &rest arglist) 34 `(let ((peak (s-save (scale *autonorm* ,expression) ,@arglist))) 35 (autonorm-update peak))) 36 37 ;; The "AutoNorm" facility: when you play something, the Nyquist play 38 ;; command will automatically compute what normalization factor you 39 ;; should have used. If you play the same thing again, the normalization 40 ;; factor is automatically applied. 41 ;; 42 ;; Call AUTONORM-OFF to turn off this feature, and AUTONORM-ON to turn 43 ;; it back on. 44 ;; 45 ;; *autonorm-target* is the peak value we're aiming for (it's set below 1 46 ;; so allow the next signal to get slightly louder without clipping) 47 ;; 48 (setf *autonorm-target* 0.9) 49 50 (defun autonorm-on () 51 (setf *autonorm* 1.0) 52 (setf *autonorm-previous-peak* 1.0) 53 (setf *autonormflag* t) 54 (format t "AutoNorm feature is on.~%")) 55 56 (if (not (boundp '*autonormflag*)) (autonorm-on)) 57 58 (defun autonorm-off () 59 (setf *autonormflag* nil) 60 (setf *autonorm* 1.0) 61 (format t "AutoNorm feature is off.~%")) 62 63 (defun autonorm-update (peak) 64 (cond ((and *autonormflag* (> peak 0.0)) 65 (setf *autonorm-previous-peak* (/ peak *autonorm*)) 66 (setf *autonorm* (/ *autonorm-target* *autonorm-previous-peak*)) 67 (format t "AutoNorm: peak was ~A,~%" *autonorm-previous-peak*) 68 (format t " peak after normalization was ~A,~%" peak) 69 (format t " new normalization factor is ~A~%" *autonorm*) 70 *autonorm-previous-peak* 71 ) 72 (t peak) 73 )) 74 75 ;; s-read -- reads a file 76 (defun s-read (filename &key (time-offset 0) (srate *sound-srate*) 77 (dur 10000.0) (nchans 1) (format *default-sf-format*) 78 (mode *default-sf-mode*) (bits *default-sf-bits*) (endian NIL)) 79 (let ((swap 0)) 80 (cond ((eq endian :big) 81 (setf swap (if ny:bigendianp 0 1))) 82 ((eq endian :little) 83 (setf swap (if ny:bigendianp 1 0)))) 84 (snd-read (soundfilename filename) time-offset 85 (local-to-global 0) format nchans mode bits swap srate 86 dur))) 87 88 ;; SF-INFO -- print sound file info 89 ;; 90 (defun sf-info (filename) 91 (let (s format channels mode bits srate dur flags) 92 (format t "~A:~%" (soundfilename filename)) 93 (setf s (s-read filename)) 94 (setf format (car *rslt*)) 95 (setf channels (cadr *rslt*)) 96 (setf mode (caddr *rslt*)) 97 (setf bits (cadddr *rslt*)) 98 (setf *rslt* (cddddr *rslt*)) 99 (setf srate (car *rslt*)) 100 (setf dur (cadr *rslt*)) 101 (setf flags (caddr *rslt*)) 102 (format t "Format: ~A~%" 103 (nth format '("none" "AIFF" "IRCAM" "NeXT" "Wave"))) 104 (cond ((setp (logand flags snd-head-channels)) 105 (format t "Channels: ~A~%" channels))) 106 (cond ((setp (logand flags snd-head-mode)) 107 (format t "Mode: ~A~%" 108 (nth mode '("ADPCM" "PCM" "uLaw" "aLaw" "Float" "UPCM"))))) 109 (cond ((setp (logand flags snd-head-bits)) 110 (format t "Bits/Sample: ~A~%" bits))) 111 (cond ((setp (logand flags snd-head-srate)) 112 (format t "SampleRate: ~A~%" srate))) 113 (cond ((setp (logand flags snd-head-dur)) 114 (format t "Duration: ~A~%" dur))) 115 )) 116 117 ;; SETP -- tests whether a bit is set (non-zero) 118 ; 119 (defun setp (bits) (not (zerop bits))) 120 121 ;; SOUNDFILENAME -- add default directory to name to get filename 122 ;; 123 (defun soundfilename (filename) 124 (cond ((= 0 (length filename)) 125 (break "filename must be at least one character long" filename)) 126 ((full-name-p filename)) 127 (t 128 ; if sf-dir nonempty and does not end with filename separator, 129 ; append one 130 (cond ((and (< 0 (length *default-sf-dir*)) 131 (not (eq (char *default-sf-dir* 132 (1- (length *default-sf-dir*))) 133 *file-separator*))) 134 (setf *default-sf-dir* (strcat *default-sf-dir* (string *file-separator*))) 135 (format t "Warning: appending \"~A\" to *default-sf-dir*~%" 136 *file-separator*))) 137 (setf filename (strcat *default-sf-dir* (string filename))))) 138 filename) 139 140 141 (setfn s-read-format car) 142 (setfn s-read-channels cadr) 143 (setfn s-read-mode caddr) 144 (setfn s-read-bits cadddr) 145 (defun s-read-swap (rslt) (car (cddddr rslt))) 146 (defun s-read-srate (rslt) (cadr (cddddr rslt))) 147 (defun s-read-dur (rslt) (caddr (cddddr rslt))) 148 (defun s-read-byte-offset (rslt) (car (cddddr (cddddr rslt)))) 149 (defun round (x) (truncate (+ 0.5 x))) 150 151 ;; change defaults for PLAY macro: 152 (setf *soundenable* t) 153 (defun sound-on () (setf *soundenable* t)) 154 (defun sound-off () (setf *soundenable* nil)) 155 156 (defmacro s-add-to (expr maxlen filename &optional time-offset) 157 `(let ((ny:fname (soundfilename ,filename)) 158 ny:input ny:rslt ny:offset 159 ) 160 (cond ((setf ny:input (s-read ny:fname :time-offset ,time-offset)) 161 (setf ny:rslt *rslt*) 162 (format t "Adding sound to ~A at offset ~A~%" 163 ny:fname ,time-offset) 164 (setf ny:offset (s-read-byte-offset ny:rslt)) 165 166 (snd-overwrite '(let ((ny:addend ,expr)) 167 (sum (snd-coterm 168 (s-read ny:fname :time-offset ,time-offset) 169 ny:addend) 170 ny:addend)) 171 ,maxlen ny:fname ny:offset 172 (s-read-mode ny:rslt) (s-read-bits ny:rslt) 173 (s-read-srate ny:rslt) (s-read-channels ny:rslt)) 174 (format t "Duration written: ~A~%" (car *rslt*))) 175 ((setf ny:input (s-read ny:fname :time-offset 0)) 176 (format t "Could not open ~A at time offset ~A~%" 177 ny:fname ,time-offset)) 178 (t 179 (format t "Could not open ~A~%" ny:fname))))) 180 181 182 (defmacro s-overwrite (expr maxlen filename &optional time-offset) 183 `(let ((ny:fname (soundfilename ,filename)) 184 ny:input ny:rslt ny:offset) 185 (setf ny:offset ,time-offset) 186 (cond ((null ny:offset) (setf ny:offset 0))) 187 (cond ((setf ny:input (s-read ny:fname :time-offset ny:offset)) 188 (setf ny:rslt *rslt*) 189 (format t "Overwriting ~A at offset ~A~%" ny:fname ny:offset) 190 (setf ny:offset (s-read-byte-offset ny:rslt)) 191 (display "s-overwrite" ny:offset) 192 (snd-overwrite `,expr ,maxlen ny:fname ny:offset 193 (s-read-format ny:rslt) 194 (s-read-mode ny:rslt) (s-read-bits ny:rslt) 195 (s-read-swap ny:rslt) 196 (s-read-srate ny:rslt) (s-read-channels ny:rslt)) 197 (format t "Duration written: ~A~%" (car *rslt*))) 198 ((s-read ny:fname :time-offset 0) 199 (format t "Could not open ~A at time offset ~A~%" 200 ny:fname ,time-offset)) 201 (t 202 (format t "Could not open ~A~%" ny:fname))))) 203 204 -
nyquist/nyquist-plot.txt
old new 1 set nokey 2 plot "points.dat" with lines 3
Note: See TracBrowser
for help on using the repository browser.