-
Data: 2012-09-20 11:57:28
Temat: Re: operacje na liczbach całkowitych a dokładność
Od: Mario <m...@...pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]W dniu 2012-09-20 09:49, Waldemar Krzok pisze:
> Am 19.09.2012 22:32, schrieb Mario:
>> W dniu 2012-09-19 19:25, Jakub Rakus pisze:
>>> Witam,
>>>
>>> Trochę już minęło czasu od zajęć z metod numerycznych... więc jak
>>> najlepiej
>>> wykonać taką operację:
>>>
>>> Mam liczbę całkowitą która maksymalnie osiąga wartość 2^13, ale muszę ją
>>> pomnożyć przez niecałkowity współczynnik, który będzie wynosił około
>>> 0,3.
>>> Zmienne wykorzystywane w obliczeniach są 16 bitowe (nie mam tyle mocy
>>> obliczeniowej żeby przejść na liczby zmiennoprzecinkowe). Ponieważ 0,3
>>> to to
>>> samo co 3/10, to mogę sobie rozbić moje działanie na mnożenie przez 3 i
>>> dzielenie bez reszty przez 10.
>>>
>>> Pytanie - jaka kolejność zapewnia większą dokładność? Najpierw mnożyć
>>> czy
>>> lepiej najpierw dzielić? Co w przypadku gdy mój współczynnik wyniesie
>>> np.
>>> 0,32 - wykonanie jako pierwszego mnożenia przez 32 (a potem dzielenia
>>> przez
>>> 100) da mi pośredni wynik większy niż zakres mojej 16-bitowej zmiennej.
>>>
>>
>> Nie napisałeś w jakim języku chcesz pisać. Jeśli w c to użyj double.
>> Jeśli w asm to musisz na potrzeby tego mnożenia napisać własną
>> procedurkę mnożenia dwóch 16 bitowych z wynikiem na np 24 czy 32 bitach.
>> Kolejność działań to oczywiście najpierw mnożenie potem dzielenie.
>>
>
> Przecież pisze wyraźnie, że nie ma mocy obliczeniowej na floaty, a ty mu
> z double wyskakujesz.
Sorki miało być long.
> Osobiście robię takie rzeczy tak, by jak najmniej stracić i szybko
> liczyć. Czyli ułamek wyrazić jako ułamek dwójkowy, czyli na przykład
> twoje 0.32 jako 41/128. Następnie mnożę dwie liczby 16to bitowe z
> wynikiem 32 bity
Zdaje się, że pytający właśnie nie wie jak zrobić żeby mieć wynik 32
bitowy.
--
pozdrawiam
MD
Następne wpisy z tego wątku
- 20.09.12 21:15 Jakub Rakus
- 20.09.12 22:30 bartekltg
- 21.09.12 20:56 Marek Wodzinski
Najnowsze wątki z tej grupy
- Czy cos fi przechodzi przez trafo separujące?
- śrubka masy
- Ciekawostka na dziś lock bity
- [OT] napisy w YT
- Było 83V
- Stare komputery
- Odbiornik ADS-B i wzmacniacze
- Thunderbird i dysk...
- opornosc falowa
- Bateria 9V 6F22, alkaliczna v cynkowa, samorozładowanie, bateria wysokiej trwałości do miernika
- Tani zakup z ali?
- w czasach LED komary mają ciężko
- walizka z kodami
- Rejestrator temperatur - termopara, siec
- Router LTE z możliwością zmian MTU
Najnowsze wątki
- 2025-08-06 Gdynia => Konsultant wdrożeniowy (systemy controlingowe) <=
- 2025-08-06 Białystok => Inżynier oprogramowania .Net <=
- 2025-08-06 "[...] sejmowe wystąpienie posłanki Klaudii Jachiry, która zakończyła je słowami ,,Sława Ukrainie"."
- 2025-08-05 "Chiny przekraczają w wydobyciu 4 mld ton węgla, Indie i USA ponad 1 mld, a Rosja 500 mln ton [...]"
- 2025-08-05 Panuje się 181 159,42 zł./mies. na posła w 2026r.
- 2025-08-05 "Chiny przekraczają w wydobyciu 4 mld ton węgla, Indie i USA ponad 1 mld, a Rosja 500 mln ton [...]"
- 2025-08-05 Czy cos fi przechodzi przez trafo separujące?
- 2025-08-05 kajaki i promile
- 2025-08-05 Re: Tesla jest bezpieczna, wczoraj spaliła się doszczętnie na Ursynowie i nikomu się nic nie stało
- 2025-08-05 Gdynia => Przedstawiciel handlowy / KAM (branża TSL) <=
- 2025-08-05 Re: Atak na lekarza w Oławie. Policja zatrzymała sprawcę na lotnisku Polska Agencja Prasowa 4 sierpnia 2025, 12:16 FACEBOOK X E-MAIL KOPIUJ LINK W szpitalu w Oławie 37-letni pacjent zaatakował lekarza, po tym, jak ten odmówił mu wypisania długoterminowego
- 2025-08-05 B2B i książka przychodów i rozchodów
- 2025-08-04 Re: Atak na lekarza w Oławie. Policja zatrzymała sprawcę na lotnisku Polska Agencja Prasowa 4 sierpnia 2025, 12:16 FACEBOOK X E-MAIL KOPIUJ LINK W szpitalu w Oławie 37-letni pacjent zaatakował lekarza, po tym, jak ten odmówił mu wypisania długoterminowego
- 2025-08-04 Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- 2025-08-04 Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML