-
Path: news-archive.icm.edu.pl!news.gazeta.pl!not-for-mail
From: " " <f...@N...gazeta.pl>
Newsgroups: pl.comp.programming
Subject: cache friendly
Date: Mon, 30 Jan 2012 09:21:33 +0000 (UTC)
Organization: "Portal Gazeta.pl -> http://www.gazeta.pl"
Lines: 85
Message-ID: <jg5net$qmn$1@inews.gazeta.pl>
NNTP-Posting-Host: localhost
Content-Type: text/plain; charset=ISO-8859-2
Content-Transfer-Encoding: 8bit
X-Trace: inews.gazeta.pl 1327915293 27351 172.20.26.241 (30 Jan 2012 09:21:33 GMT)
X-Complaints-To: u...@a...pl
NNTP-Posting-Date: Mon, 30 Jan 2012 09:21:33 +0000 (UTC)
X-User: fir
X-Forwarded-For: 31.61.130.246
X-Remote-IP: localhost
Xref: news-archive.icm.edu.pl pl.comp.programming:194929
[ ukryj nagłówki ]na czym polega pisanie cache friendly?
jak przepisac kod na wersje bardziej cache
friendly?
czy da sie patrzac na kod i wiedzac ile
procek ma cache projektowac tak struktury
danych by procek wyrabial sie w cache?
(w sensie rozroznienia pisania 'slabego' i 'mocnego'
chache friendly)
np jesli mam gierke z jakas duza iloscia agentow
i ich dane trzymam w tablicy agent[] to wiekszosc
kodu update() dziala niemal wylacznie na tej
teblicy agent[]
ale sa jeszcze funkcje draw() (dla kazdego agenta)
ktore dzialaj na danych agent[] i pisza do drugiej
tablicy pixelbufor[]
sam decyduje czy mam przeplatac drawy z updatami
for(int i=0; i<1000; i++)
{
agent_update(i);
agent_draw(i)
}
czy tez nie przeplatac :
for(int i=0; i<1000; i++) // uzywa agent[]
agent_update(i);
for(int i=0; i<1000; i++) // uzywa agent[] i pixelbufor[]
agent_draw(i)
druga forma wydaje sie ew bardziej cache
friendly
czy sa jakies dobrze okreslone reguly by pisac
kod mocno cache firendly?
((
oprocz kache friendly wydaje mi sie ze warto zwracac uwage
na align friendly (niestety nie wiem czy w c jest jakis
standardowy (np slowo kluczowe) sposob okreslania alignmentów
(w sumie dwu bo chodzi o poczatek i rozlozenie)
osobiscie wolalbym by dane byly w strukturach jednak upakowywane
ale pewne mechanizmy do automatycznego jak i jawnego narzucania
alignmentu by tez sie przydaly
pozatym jest jeszcze cos co bym nazwal fpu friendly - jest
zdaje sie cos co powoduje ze albo rzutowanie albo przelaczanie
int / float potrafi byc masakrycznie kosztowne (czytalem cos
w tutorialu gourleya o dynamice plynow ale nie doczytalem)
a jakos malo ludzi ma ta swiadomosc
[np
By default, the floating-point unit (FPU) converts floating-point
values to integers using rounding; but C specifies truncation. So
each float-to-int conversion requires changing the FPU mode to
“truncation,” but to do that safely requires first saving the old
control word, then restoring it after the conversion.
o tyle jest to pewien szok - rzutowanie z floata na inta moze
byc a zapewne jest b wolne (jesli powoduje zapisanie i odczytanie
'ustawien' fpu :/
]
jeszcze jakies metodyki optymisation friendly?
moze jakies zaawansowane artykuly do optymalizacji?
))
--
Wysłano z serwisu Usenet w portalu Gazeta.pl -> http://www.gazeta.pl/usenet/
Następne wpisy z tego wątku
Najnowsze wątki z tej grupy
- Na grupie comp.os.linux.advocacy CrudeSausage twierdzi, że Micro$lop używa SI do szyfrowania formatu dok. XML
- Błąd w Sofcie Powodem Wymiany 3 Duńskich Fregat Typu Iver Huitfeldt
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
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