unofficial mirror of emacs-devel@gnu.org 
 help / color / mirror / code / Atom feed
* osc-insert-float32
@ 2019-12-17 18:04 Mario Lang
  2019-12-17 18:25 ` osc-insert-float32 Andreas Schwab
                   ` (3 more replies)
  0 siblings, 4 replies; 6+ messages in thread
From: Mario Lang @ 2019-12-17 18:04 UTC (permalink / raw)
  To: emacs-devel

Hi.

14 years ago, I wrote this beast to be able to send IEEE floating point
values over the network (Open Sound Control).  Reading it today, I am
actually surprised I was driven enough to get this working.  I am
wondering, is there a better way to achieve this today?
Maybe something in Emacs itself I missed?

If no, is there a better way to test for negative zero and 0.0e+NaN?

;; From elpa package osc.el
(defun osc-insert-float32 (value)
  (let (s (e 0) f)
    (cond
     ((string= (format "%f" value) (format "%f" -0.0))
      (setq s 1 f 0))
     ((string= (format "%f" value) (format "%f" 0.0))
      (setq s 0 f 0))
     ((= value 1.0e+INF)
      (setq s 0 e 255 f (1- (expt 2 23))))
     ((= value -1.0e+INF)
      (setq s 1 e 255 f (1- (expt 2 23))))
     ((string= (format "%f" value) (format "%f" 0.0e+NaN))
      (setq s 0 e 255 f 1))
     (t
      (setq s (if (>= value 0.0)
		  (progn (setq f value) 0)
		(setq f (* -1 value)) 1))
      (while (>= (* f (expt 2.0 e)) 2.0) (setq e (1- e)))
      (if (= e 0) (while (< (* f (expt 2.0 e)) 1.0) (setq e (1+ e))))
      (setq f (round (* (1- (* f (expt 2.0 e))) (expt 2 23)))
	    e (+ (* -1 e) 127))))
    (insert (+ (lsh s 7) (lsh (logand e #XFE) -1))
	    (+ (lsh (logand e #X01) 7) (lsh (logand f #X7F0000) -16))
	    (lsh (logand f #XFF00) -8)
	    (logand f #XFF))))

-- 
CYa,
  ⡍⠁⠗⠊⠕



^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2022-09-30 19:33 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-12-17 18:04 osc-insert-float32 Mario Lang
2019-12-17 18:25 ` osc-insert-float32 Andreas Schwab
2019-12-17 19:02 ` osc-insert-float32 Stefan Monnier
2019-12-17 21:10   ` osc-insert-float32 Mario Lang
2022-09-30 19:02 ` osc-insert-float32 DIRO
2022-09-30 19:33 ` osc-insert-float32 Andreas Schwab

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).