From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00 autolearn=ham autolearn_force=no version=3.4.4 X-Google-Thread: a07f3367d7,fa37ee962bc4b00d,start X-Google-Attributes: gida07f3367d7,public,usenet X-Google-NewGroupId: yes X-Google-Language: ENGLISH,ASCII-7-bit Path: g2news2.google.com!news1.google.com!news.glorb.com!feeder.erje.net!feeder2.ecngs.de!ecngs!feeder.ecngs.de!feed1.news.be.easynet.net!news.skynet.be!195.238.0.222.MISMATCH!newsspl501.isp.belgacom.be!tjb!not-for-mail Date: Tue, 19 May 2009 20:51:23 +0200 From: Olivier Scalbert User-Agent: Thunderbird 2.0.0.21 (X11/20090318) MIME-Version: 1.0 Newsgroups: comp.lang.ada Subject: Conversion from floating point to signed 16 bits Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Message-ID: <4a12ffa3$0$2853$ba620e4c@news.skynet.be> Organization: -= Belgacom Usenet Service =- NNTP-Posting-Host: 418685ff.news.skynet.be X-Trace: 1242759075 news.skynet.be 2853 87.65.144.169:37897 X-Complaints-To: usenet-abuse@skynet.be Xref: g2news2.google.com comp.lang.ada:5945 Date: 2009-05-19T20:51:23+02:00 List-Id: Hello, My problem: I need to convert an "analogic" value which can vary from 0.0 to 1.0 into a "discrete" value which is a signed 16 bits integer. My implementation: ----------------------------- with Ada.Text_IO; procedure convert is type Analog_Value is digits 10 range 0.0 .. 1.0; type Signed_16 is range -32768 .. 32767; type Unsigned_16 is range 0 .. 65535; function Cv(Value: Analog_Value) return Signed_16 is U16: Unsigned_16; begin U16 := Unsigned_16(65535.0 * Value); return Signed_16(U16 - 32768); end Cv; procedure Put(S16: Signed_16) is begin Ada.Text_IO.Put_Line(Signed_16'image(S16)); end put; begin Put(Cv(0.00)); -- Must be -32768 Put(Cv(0.25)); -- Must be -16384 Put(Cv(0.50)); -- Must be 0 Put(Cv(0.75)); -- Must be 16383 Put(Cv(1.00)); -- Must be 32767 end convert; ----------------------------- My question: Is there an other way to do this in Ada (Representation ? Other parts of Ada I do not know ?) My thanks: Thank you very much ! ;-) Olivier.