11 000 010 101 100 111 009 999 999 999 849 scris ca binar pe 32 biți, precizie simplă, virgulă mobilă în standard IEEE 754

Scriere 11 000 010 101 100 111 009 999 999 999 849(10) din zecimal în binar pe 32 de biți, precizie simplă, în virgulă mobilă în standard IEEE 754 (1 bit pentru semn, 8 biți pentru exponent, 23 de biți pentru mantisă)

Care sunt pașii pentru a scrie numărul
11 000 010 101 100 111 009 999 999 999 849(10) din zecimal în binar în reprezentarea pe 32 biți, precizie simplă, în virgulă mobilă în standard IEEE 754 (1 bit pentru semn, 8 biți pentru exponent, 23 de biți pentru mantisă)

1. Împarte numărul în mod repetat la 2.

Notăm mai jos, în ordine, fiecare rest al împărțirilor.

Ne oprim când obținem un cât egal cu zero.


  • împărțire = cât + rest;
  • 11 000 010 101 100 111 009 999 999 999 849 : 2 = 5 500 005 050 550 055 504 999 999 999 924 + 1;
  • 5 500 005 050 550 055 504 999 999 999 924 : 2 = 2 750 002 525 275 027 752 499 999 999 962 + 0;
  • 2 750 002 525 275 027 752 499 999 999 962 : 2 = 1 375 001 262 637 513 876 249 999 999 981 + 0;
  • 1 375 001 262 637 513 876 249 999 999 981 : 2 = 687 500 631 318 756 938 124 999 999 990 + 1;
  • 687 500 631 318 756 938 124 999 999 990 : 2 = 343 750 315 659 378 469 062 499 999 995 + 0;
  • 343 750 315 659 378 469 062 499 999 995 : 2 = 171 875 157 829 689 234 531 249 999 997 + 1;
  • 171 875 157 829 689 234 531 249 999 997 : 2 = 85 937 578 914 844 617 265 624 999 998 + 1;
  • 85 937 578 914 844 617 265 624 999 998 : 2 = 42 968 789 457 422 308 632 812 499 999 + 0;
  • 42 968 789 457 422 308 632 812 499 999 : 2 = 21 484 394 728 711 154 316 406 249 999 + 1;
  • 21 484 394 728 711 154 316 406 249 999 : 2 = 10 742 197 364 355 577 158 203 124 999 + 1;
  • 10 742 197 364 355 577 158 203 124 999 : 2 = 5 371 098 682 177 788 579 101 562 499 + 1;
  • 5 371 098 682 177 788 579 101 562 499 : 2 = 2 685 549 341 088 894 289 550 781 249 + 1;
  • 2 685 549 341 088 894 289 550 781 249 : 2 = 1 342 774 670 544 447 144 775 390 624 + 1;
  • 1 342 774 670 544 447 144 775 390 624 : 2 = 671 387 335 272 223 572 387 695 312 + 0;
  • 671 387 335 272 223 572 387 695 312 : 2 = 335 693 667 636 111 786 193 847 656 + 0;
  • 335 693 667 636 111 786 193 847 656 : 2 = 167 846 833 818 055 893 096 923 828 + 0;
  • 167 846 833 818 055 893 096 923 828 : 2 = 83 923 416 909 027 946 548 461 914 + 0;
  • 83 923 416 909 027 946 548 461 914 : 2 = 41 961 708 454 513 973 274 230 957 + 0;
  • 41 961 708 454 513 973 274 230 957 : 2 = 20 980 854 227 256 986 637 115 478 + 1;
  • 20 980 854 227 256 986 637 115 478 : 2 = 10 490 427 113 628 493 318 557 739 + 0;
  • 10 490 427 113 628 493 318 557 739 : 2 = 5 245 213 556 814 246 659 278 869 + 1;
  • 5 245 213 556 814 246 659 278 869 : 2 = 2 622 606 778 407 123 329 639 434 + 1;
  • 2 622 606 778 407 123 329 639 434 : 2 = 1 311 303 389 203 561 664 819 717 + 0;
  • 1 311 303 389 203 561 664 819 717 : 2 = 655 651 694 601 780 832 409 858 + 1;
  • 655 651 694 601 780 832 409 858 : 2 = 327 825 847 300 890 416 204 929 + 0;
  • 327 825 847 300 890 416 204 929 : 2 = 163 912 923 650 445 208 102 464 + 1;
  • 163 912 923 650 445 208 102 464 : 2 = 81 956 461 825 222 604 051 232 + 0;
  • 81 956 461 825 222 604 051 232 : 2 = 40 978 230 912 611 302 025 616 + 0;
  • 40 978 230 912 611 302 025 616 : 2 = 20 489 115 456 305 651 012 808 + 0;
  • 20 489 115 456 305 651 012 808 : 2 = 10 244 557 728 152 825 506 404 + 0;
  • 10 244 557 728 152 825 506 404 : 2 = 5 122 278 864 076 412 753 202 + 0;
  • 5 122 278 864 076 412 753 202 : 2 = 2 561 139 432 038 206 376 601 + 0;
  • 2 561 139 432 038 206 376 601 : 2 = 1 280 569 716 019 103 188 300 + 1;
  • 1 280 569 716 019 103 188 300 : 2 = 640 284 858 009 551 594 150 + 0;
  • 640 284 858 009 551 594 150 : 2 = 320 142 429 004 775 797 075 + 0;
  • 320 142 429 004 775 797 075 : 2 = 160 071 214 502 387 898 537 + 1;
  • 160 071 214 502 387 898 537 : 2 = 80 035 607 251 193 949 268 + 1;
  • 80 035 607 251 193 949 268 : 2 = 40 017 803 625 596 974 634 + 0;
  • 40 017 803 625 596 974 634 : 2 = 20 008 901 812 798 487 317 + 0;
  • 20 008 901 812 798 487 317 : 2 = 10 004 450 906 399 243 658 + 1;
  • 10 004 450 906 399 243 658 : 2 = 5 002 225 453 199 621 829 + 0;
  • 5 002 225 453 199 621 829 : 2 = 2 501 112 726 599 810 914 + 1;
  • 2 501 112 726 599 810 914 : 2 = 1 250 556 363 299 905 457 + 0;
  • 1 250 556 363 299 905 457 : 2 = 625 278 181 649 952 728 + 1;
  • 625 278 181 649 952 728 : 2 = 312 639 090 824 976 364 + 0;
  • 312 639 090 824 976 364 : 2 = 156 319 545 412 488 182 + 0;
  • 156 319 545 412 488 182 : 2 = 78 159 772 706 244 091 + 0;
  • 78 159 772 706 244 091 : 2 = 39 079 886 353 122 045 + 1;
  • 39 079 886 353 122 045 : 2 = 19 539 943 176 561 022 + 1;
  • 19 539 943 176 561 022 : 2 = 9 769 971 588 280 511 + 0;
  • 9 769 971 588 280 511 : 2 = 4 884 985 794 140 255 + 1;
  • 4 884 985 794 140 255 : 2 = 2 442 492 897 070 127 + 1;
  • 2 442 492 897 070 127 : 2 = 1 221 246 448 535 063 + 1;
  • 1 221 246 448 535 063 : 2 = 610 623 224 267 531 + 1;
  • 610 623 224 267 531 : 2 = 305 311 612 133 765 + 1;
  • 305 311 612 133 765 : 2 = 152 655 806 066 882 + 1;
  • 152 655 806 066 882 : 2 = 76 327 903 033 441 + 0;
  • 76 327 903 033 441 : 2 = 38 163 951 516 720 + 1;
  • 38 163 951 516 720 : 2 = 19 081 975 758 360 + 0;
  • 19 081 975 758 360 : 2 = 9 540 987 879 180 + 0;
  • 9 540 987 879 180 : 2 = 4 770 493 939 590 + 0;
  • 4 770 493 939 590 : 2 = 2 385 246 969 795 + 0;
  • 2 385 246 969 795 : 2 = 1 192 623 484 897 + 1;
  • 1 192 623 484 897 : 2 = 596 311 742 448 + 1;
  • 596 311 742 448 : 2 = 298 155 871 224 + 0;
  • 298 155 871 224 : 2 = 149 077 935 612 + 0;
  • 149 077 935 612 : 2 = 74 538 967 806 + 0;
  • 74 538 967 806 : 2 = 37 269 483 903 + 0;
  • 37 269 483 903 : 2 = 18 634 741 951 + 1;
  • 18 634 741 951 : 2 = 9 317 370 975 + 1;
  • 9 317 370 975 : 2 = 4 658 685 487 + 1;
  • 4 658 685 487 : 2 = 2 329 342 743 + 1;
  • 2 329 342 743 : 2 = 1 164 671 371 + 1;
  • 1 164 671 371 : 2 = 582 335 685 + 1;
  • 582 335 685 : 2 = 291 167 842 + 1;
  • 291 167 842 : 2 = 145 583 921 + 0;
  • 145 583 921 : 2 = 72 791 960 + 1;
  • 72 791 960 : 2 = 36 395 980 + 0;
  • 36 395 980 : 2 = 18 197 990 + 0;
  • 18 197 990 : 2 = 9 098 995 + 0;
  • 9 098 995 : 2 = 4 549 497 + 1;
  • 4 549 497 : 2 = 2 274 748 + 1;
  • 2 274 748 : 2 = 1 137 374 + 0;
  • 1 137 374 : 2 = 568 687 + 0;
  • 568 687 : 2 = 284 343 + 1;
  • 284 343 : 2 = 142 171 + 1;
  • 142 171 : 2 = 71 085 + 1;
  • 71 085 : 2 = 35 542 + 1;
  • 35 542 : 2 = 17 771 + 0;
  • 17 771 : 2 = 8 885 + 1;
  • 8 885 : 2 = 4 442 + 1;
  • 4 442 : 2 = 2 221 + 0;
  • 2 221 : 2 = 1 110 + 1;
  • 1 110 : 2 = 555 + 0;
  • 555 : 2 = 277 + 1;
  • 277 : 2 = 138 + 1;
  • 138 : 2 = 69 + 0;
  • 69 : 2 = 34 + 1;
  • 34 : 2 = 17 + 0;
  • 17 : 2 = 8 + 1;
  • 8 : 2 = 4 + 0;
  • 4 : 2 = 2 + 0;
  • 2 : 2 = 1 + 0;
  • 1 : 2 = 0 + 1;

2. Construiește reprezentarea numărului pozitiv în baza 2.

Ia fiecare rest al împărțirilor începând din partea de jos a listei construite mai sus.

11 000 010 101 100 111 009 999 999 999 849(10) =


1000 1010 1101 0110 1111 0011 0001 0111 1111 0000 1100 0010 1111 1101 1000 1010 1001 1001 0000 0010 1011 0100 0001 1111 0110 1001(2)


3. Normalizează reprezentarea binară a numărului.

Mută virgula cu 103 poziții la stânga, astfel încât partea întreagă a acestuia să aibă un singur bit, diferit de 0:


11 000 010 101 100 111 009 999 999 999 849(10) =


1000 1010 1101 0110 1111 0011 0001 0111 1111 0000 1100 0010 1111 1101 1000 1010 1001 1001 0000 0010 1011 0100 0001 1111 0110 1001(2) =


1000 1010 1101 0110 1111 0011 0001 0111 1111 0000 1100 0010 1111 1101 1000 1010 1001 1001 0000 0010 1011 0100 0001 1111 0110 1001(2) × 20 =


1,0001 0101 1010 1101 1110 0110 0010 1111 1110 0001 1000 0101 1111 1011 0001 0101 0011 0010 0000 0101 0110 1000 0011 1110 1101 001(2) × 2103


4. Până la acest moment avem următoarele elemente ce vor alcătui numărul binar în reprezentare IEEE 754, precizie simplă (32 biți):

Semn 0 (un număr pozitiv)


Exponent (neajustat): 103


Mantisă (nenormalizată):
1,0001 0101 1010 1101 1110 0110 0010 1111 1110 0001 1000 0101 1111 1011 0001 0101 0011 0010 0000 0101 0110 1000 0011 1110 1101 001


5. Ajustează exponentul.

Folosește reprezentarea deplasată pe 8 biți:


Exponent (ajustat) =


Exponent (neajustat) + 2(8-1) - 1 =


103 + 2(8-1) - 1 =


(103 + 127)(10) =


230(10)


6. Convertește exponentul ajustat din zecimal (baza 10) în binar pe 8 biți.

Folosește din nou tehnica împărțirii repetate la 2:


  • împărțire = cât + rest;
  • 230 : 2 = 115 + 0;
  • 115 : 2 = 57 + 1;
  • 57 : 2 = 28 + 1;
  • 28 : 2 = 14 + 0;
  • 14 : 2 = 7 + 0;
  • 7 : 2 = 3 + 1;
  • 3 : 2 = 1 + 1;
  • 1 : 2 = 0 + 1;

7. Construiește reprezentarea în baza 2 a exponentului ajustat.

Ia fiecare rest al împărțirilor începând din partea de jos a listei construite mai sus.


Exponent (ajustat) =


230(10) =


1110 0110(2)


8. Normalizează mantisa.

a) Renunță la primul bit, cel mai din stânga, care e întotdeauna 1, și la separatorul zecimal, dacă e cazul.


b) Ajustează-i lungimea la 23 biți, prin renunțarea la biții în exces, din dreapta (dacă măcar unul din acești biți în exces e setat pe 1, se pierde din precizie...).


Mantisă (normalizată) =


1. 000 1010 1101 0110 1111 0011 0001 0111 1111 0000 1100 0010 1111 1101 1000 1010 1001 1001 0000 0010 1011 0100 0001 1111 0110 1001 =


000 1010 1101 0110 1111 0011


9. Cele trei elemente care alcătuiesc reprezentarea numărului în sistem binar pe 32 de biți, precizie simplă, în virgulă mobilă în standard IEEE 754:

Semn (1 bit) =
0 (un număr pozitiv)


Exponent (8 biți) =
1110 0110


Mantisă (23 biți) =
000 1010 1101 0110 1111 0011


Numărul zecimal 11 000 010 101 100 111 009 999 999 999 849 scris în binar în representarea pe 32 biți, precizie simplă, în virgulă mobilă în standard IEEE 754:

0 - 1110 0110 - 000 1010 1101 0110 1111 0011


Cum să convertești numere zecimale din sistem zecimal (baza 10) în sistem binar în virgulă mobilă în reprezentarea IEEE 754, precizie simplă pe 32 de biți

Urmează pașii de mai jos pentru a converti un număr zecimal (cu virgulă) din baza zece în sistem binar în virgulă mobilă în reprezentarea IEEE 754, precizie simplă pe 32 de biți:

  • 1. Dacă numărul de convertit este negativ, se începe cu versiunea pozitivă a numărului.
  • 2. Se convertește întâi partea întreagă; împarte în mod repetat la 2 reprezentarea pozitivă a numărului întreg cu semn care trebuie convertit în sistem binar, ținând minte fiecare rest al împărțirilor. Atunci când găsim un CÂT care e egal cu ZERO => STOP
  • 3. Construiește reprezentarea în baza 2 a părții întregi a numărului, luând fiecare rest al împărțirilor începând din partea de jos a listei construite mai sus. Astfel, ultimul rest al împărțirilor de la punctul de mai sus devine primul simbol (situat cel mai la stânga) al numărului în baza doi, în timp ce primul rest devine ultimul simbol (situat cel mai la dreapta).
  • 4. Convertește apoi partea fracționară. Înmulțește în mod repetat cu 2, până se obține o parte fracționară egală cu zero, ținând minte fiecare parte întreagă a înmulțirilor.
  • 5. Construiește reprezentarea în baza 2 a părții fracționare a numărului, luând fiecare parte întreagă a rezultatelor înmulțirilor de mai sus, începând din partea de sus a listei construite (se iau părțile întregi în ordinea în care au fost obținute).
  • 6. Normalizează reprezentarea binară a numărului, mutând virgula cu "n" poziții la stânga (sau, dacă e cazul, la dreapta) astfel încât partea întreagă a acestuia să mai conțină un singur bit, diferit de '0'.
  • 7. Ajustează exponentul folosind reprezentarea deplasată pe 8 biți apoi convertește-l din zecimal (baza 10) în binar pe 8 biți, folosind tehnica împărțirii repetate la 2, așa cum am mai arătat mai sus:
    Exponent (ajustat) = Exponent (neajustat) + 2(8-1) - 1;
  • 8. Normalizează mantisa, renunțând la primul bit (cel mai din stânga), care este întotdeauna '1' (și la semnul zecimal, dacă e cazul) și ajustându-i lungimea, la 23 biți, fie renunțând la biții în exces, din dreapta (pierzând precizie...) fie adaugând tot la dreapta biți setați pe '0'.
  • 9. Semnul (ocupă 1 bit) este egal fie cu 1, dacă este un număr negativ, fie cu 0, dacă e un număr pozitiv.

Exemplu: convertește numărul negativ -25,347 din sistem zecimal (baza zece) în sistem binar în virgulă mobilă în reprezentarea IEEE 754, precizie simplă pe 32 de biți:

  • 1. Se începe cu versiunea pozitivă a numărului:

    |-25,347| = 25,347;

  • 2. Convertește întâi partea întreagă, 25. Împarte în mod repetat la 2, ținând minte fiecare rest al împărțirilor, până obținem un cât care este egal cu zero:
    • împărțire = cât + rest;
    • 25 : 2 = 12 + 1;
    • 12 : 2 = 6 + 0;
    • 6 : 2 = 3 + 0;
    • 3 : 2 = 1 + 1;
    • 1 : 2 = 0 + 1;
    • Am obținut un cât care este egal cu ZERO => STOP
  • 3. Construiește reprezentarea în baza 2 a părții întregi a numărului, luând fiecare rest al împărțirilor începând din partea de jos a listei construite mai sus:

    25(10) = 1 1001(2)

  • 4. Convertește apoi partea fracționară 0,347. Înmulțește în mod repetat cu 2, ținând minte fiecare parte întreagă a înmulțirilor, până obținem o parte fracționară egală cu zero:
    • #) înmulțire = întreg + fracționar;
    • 1) 0,347 × 2 = 0 + 0,694;
    • 2) 0,694 × 2 = 1 + 0,388;
    • 3) 0,388 × 2 = 0 + 0,776;
    • 4) 0,776 × 2 = 1 + 0,552;
    • 5) 0,552 × 2 = 1 + 0,104;
    • 6) 0,104 × 2 = 0 + 0,208
    • 7) 0,208 × 2 = 0 + 0,416;
    • 8) 0,416 × 2 = 0 + 0,832;
    • 9) 0,832 × 2 = 1 + 0,664;
    • 10) 0,664 × 2 = 1 + 0,328;
    • 11) 0,328 × 2 = 0 + 0,656;
    • 12) 0,656 × 2 = 1 + 0,312;
    • 13) 0,312 × 2 = 0 + 0,624;
    • 14) 0,624 × 2 = 1 + 0,248;
    • 15) 0,248 × 2 = 0 + 0,496;
    • 16) 0,496 × 2 = 0 + 0,992;
    • 17) 0,992 × 2 = 1 + 0,984;
    • 18) 0,984 × 2 = 1 + 0,968;
    • 19) 0,968 × 2 = 1 + 0,936;
    • 20) 0,936 × 2 = 1 + 0,872;
    • 21) 0,872 × 2 = 1 + 0,744;
    • 22) 0,744 × 2 = 1 + 0,488;
    • 23) 0,488 × 2 = 0 + 0,976;
    • 24) 0,976 × 2 = 1 + 0,952;
    • Nicio parte fracționară egală cu zero n-a fost obținută prin calcule. Însă am efectuat un număr suficient de iterații (peste limita de Mantisă = 23) și a fost găsită prin calcule măcar o parte întreagă diferită de zero => STOP (pierzând precizie...).
  • 5. Construiește reprezentarea în baza 2 a părții fracționare a numărului, luând fiecare parte întreagă a rezultatelor înmulțirilor efectuate anterior, începând din partea de sus a listei construite:

    0,347(10) = 0,0101 1000 1101 0100 1111 1101(2)

  • 6. Recapitulare - numărul pozitiv înainte de normalizare:

    25,347(10) = 1 1001,0101 1000 1101 0100 1111 1101(2)

  • 7. Normalizează reprezentarea binară a numărului, mutând virgula cu 4 poziții la stânga astfel încât partea întreagă a acestuia să aibă un singur bit, diferit de '0':

    25,347(10) =
    1 1001,0101 1000 1101 0100 1111 1101(2) =
    1 1001,0101 1000 1101 0100 1111 1101(2) × 20 =
    1,1001 0101 1000 1101 0100 1111 1101(2) × 24

  • 8. Până în acest moment avem următoarele elemente ce vor alcătui numărul binar în reprezentare IEEE 754, precizie simplă (32 biți):

    Semn: 1 (număr negativ);

    Exponent (neajustat): 4;

    Mantisă (nenormalizată): 1,1001 0101 1000 1101 0100 1111 1101;

  • 9. Ajustează exponentul folosind reprezentarea deplasată pe 8 biți apoi convertește-l din zecimal (baza 10) în binar (baza 2) pe 8 biți, folosind tehnica împărțirii repetate la 2, așa cum am mai arătat mai sus, ținând minte toate resturile, ce vor alcătui numărul în binar:

    Exponent (ajustat) = Exponent (neajustat) + 2(8-1) - 1 = (4 + 127)(10) = 131(10) =
    1000 0011(2)

  • 10. Normalizează mantisa, renunțând la primul bit (cel mai din stânga), care este întotdeauna '1' (și la semnul zecimal) și ajustându-i lungimea la 23 biți, prin renunțarea la biții în exces, cei din dreapta (pierzând precizie...):

    Mantisă (nenormalizată): 1,1001 0101 1000 1101 0100 1111 1101

    Mantisă (normalizată): 100 1010 1100 0110 1010 0111

  • Concluzia:

    Semn (1 bit) = 1 (un număr negativ)

    Exponent (8 biți) = 1000 0011

    Mantisă (23 biți) = 100 1010 1100 0110 1010 0111

  • Numărul -25,347 convertit din sistem zecimal (baza 10) în binar pe 32 de biți, precizie simplă, în virgulă mobilă în standard IEEE 754 este:
    1 - 1000 0011 - 100 1010 1100 0110 1010 0111