diff --git a/Organizacja zajęć na przedmiotach SYI oraz PBR.ipynb b/Organizacja zajęć na przedmiotach SYI oraz PBR.ipynb
new file mode 100644
index 0000000..dee3356
--- /dev/null
+++ b/Organizacja zajęć na przedmiotach SYI oraz PBR.ipynb
@@ -0,0 +1,257 @@
+{
+ "cells": [
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# Organizacja zajęć na przedmiotach PPB, SYI oraz PBR"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# 1. Założenia ogólne"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## 1.1. Przygotowanie do projektu badawczo-rozwojowego (PPB)\n",
+ "Przygotowanie do projektu badawczo-rozwojowego to przedmiot prowadzony w formie wykładów dla studentów II roku studiów magisterskich na kierunku Informatyka. \n",
+ "Celem przedmiotu jest zaznajomienie studentów z przebiegiem tworzenia projektu badawczo-rozwojowego."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## 1.2. Projekt badawczo-rozwojowy (PBR)\n",
+ "Projekt badawczo-rozwojowy to przedmiot prowadzony w formie laboratoriów dla studentów II roku studiów magisterskich na kierunku informatyka.\n",
+ "\n",
+ "Wskazane jest, aby projekt badawczo-rozwojowy przyczyniał się do rozwoju prac magisterskich członków zespołu.\n",
+ "\n",
+ "* Student informatyki powinien nabyć następujące umiejętności:\n",
+ " * tworzenie koncepcji projektu badawczo-rozwojowego,\n",
+ " * implementacja systemu informatycznego w metodyce zwinnej,\n",
+ " * stosowanie praktyki ciągłej integracji w rozwoju systemu informatycznego,\n",
+ " * wdrożenie systemu będącego wynikiem projektu badawczo-rozwojowego w praktyce gospodarczej."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "## 1.3. Systemy informatyczne (SYI)\n",
+ "Systemy informatyczne to przedmiot prowadzony w formie wykładów i laboratoriów dla studentów III semestru studiów magisterskich na kierunku Analiza i Przetwarzanie Danych. \n",
+ "Celem przedmiotu jest zaznajomienie studentów z przebiegiem tworzenia systemu informatycznego - na przykładzie projektu badawczo-rozwojowego rozwijanego przez studentów studiów magisterskich na kierunku Informatyka. \n",
+ "W ramach laboratorium do przedmiotu SYI studenci uczestniczą w tworzeniu projektów badawczo-rozwojowych razem ze studentami Informatyki.\n",
+ "\n",
+ " * Student analizy i przetwarzania danych powinien nabyć następujące umiejętności:\n",
+ "\n",
+ " * dostarczanie i analiza danych do systemu informatycznego,\n",
+ " * tworzenie dokumentacji projektowej,\n",
+ " * przygotowanie i prowadzenie testów funkcjonalnych,\n",
+ " * opracowanie raportów użyteczności,\n",
+ " * tworzenie skryptów wspomagających implementację i testowanie."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# 2. Współpraca studentów na przedmiotach SYI oraz PBR\n",
+ "\n",
+ "Studenci przedmiotów SYI oraz PBR współpracują ze sobą, tworząc razem zespoły o liczności od trzech do pięciu studentów. W skład zespołów wchodzą studenci obu przedmiotów. \n",
+ "\n",
+ "Aby umożliwić taką współpracę, laboratoria z przedmiotów SYI i PBR prowadzone są w ten sam dzień tygodnia i o tej samej godzinie. Studenci obu kierunków współpracują w tworzeniu wspólnego projektu badawczo-rozwojowego. \n",
+ "\n",
+ "Zespół projektowy powinien zatem składać się ze studentów obu kierunków (idealnie: dwóch studentów informatyki i dwóch studentów analizy danych). Skład zespołów może się kształtować podczas pierwszych trzech laboratoriów. Począwszy od laboratorium nr 4 studenci pracują w stałych zespołach.\n",
+ "\n",
+ "Każdy zespół ma opiekuna - osobę z kadry WMI UAM.\n",
+ "\n",
+ "Opiekunowie otrzymują od wykładowcy przedmiotu PPB proponowane scenariusze wszystkich laboratoriów przedmiotu PBR wraz z wytycznymi dotyczącymi oceniania pracy studentów. Opiekun projektu ma jednak prawo odstąpić od proponowanych scenariuszy - częściowo lub w całości, dostosowując przebieg laboratorium do specyfiki projektu. \n",
+ "\n",
+ "W każdym wypadku wymaga się jednak, aby praca projektowa była udokumentowana."
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# 3. Zasady zaliczenia wykładów PPB i SYI\n",
+ "Zasady zaliczania wykładów PPB i SYI są takie same.\n",
+ "\n",
+ "Wykład może być zaliczony albo na podstawie punktów uzyskanych za rozwiązywanie testów podawanych na wykładzie, albo poprzez egzamin końcowy. \n",
+ "\n",
+ "Za prawidłowe odpowiedzi na pytania testowe podawane podczas wykładu studenci otrzymują punkty (1 punkt za prawidłową odpowiedź). Testy rozwiązywane mogą być na dowolnych urządzeniach, które dysponują przeglądarką internetową. System do testów jest osiągalny pod adresem: \n",
+ " **cybertest2.wmi.amu.edu.pl** \n",
+ "Logowanie do systemu odbywa się za pomocą standardowych danych dostępowych na WMI. \n",
+ "\n",
+ "Wykładowca zobowiązuje się do przeprowadzenia testów z minimum 120 pytaniami podczas całego kursu (standardowo: 5 pytań powtórkowych na początku wykładu i 5 pytań na końcu wykładu). \n",
+ "\n",
+ "### Zwolnienia z egzaminu\n",
+ "Student zwolniony jest z egzaminu z oceną dostateczny plus lub wyższą, wynikającą z punktów zdobytych za rozwiązanie zadań testowych podawanych na wykładach. \n",
+ "\n",
+ "Studenci niespełniający powyższego kryterium zdają egzamin obejmujący materiał przedstawiany na wykładach. Studenci mogą zdawać egzamin również w sytuacji, gdy nie satysfakcjonuje ich ocena uzyskana na podstawie zdobytych punktów.\n",
+ "\n",
+ "### Skala ocen z wykładu \n",
+ "
\n",
+ " \n",
+ " Liczba prawidłowych odpowiedzi | Ocena | \n",
+ "
\n",
+ " \n",
+ " 100-120 | 5 | \n",
+ "
\n",
+ " \n",
+ " 90-99 | 4,5 | \n",
+ "
\n",
+ " \n",
+ " 80-89 | 4 | \n",
+ "
\n",
+ " \n",
+ " 70-79 | 3,5 | \n",
+ "
\n",
+ " \n",
+ " poniżej | egzamin | \n",
+ "
\n",
+ "
\n"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "# 4. Zasady zaliczenia z laboratoriów PBR i SYI\n",
+ "\n",
+ "Zasady zaliczenia obu przedmiotów są takie same.\n",
+ "\n",
+ "## Ocena końcowa z przedmiotu PBR\n",
+ "Studentom informatyki ocenę końcową z laboratorium wystawia opiekun projektu badawczo-rozwojowego.\n",
+ "\n",
+ "## Ocena końcowa z laboratorium SYI\n",
+ "Studentom analizy i przetwarzania danych ocenę końcową wystawia prowadzący laboratorium na wniosek opiekuna projektu badawczo-rozwojowego.\n",
+ "\n",
+ "## Proponowana punktacja zadań wykonywanych na przedmiocie PBR\n",
+ "\n",
+ " \n",
+ " Typ zadania | Liczba punktów | \n",
+ "
\n",
+ " \n",
+ " Zadania na laboratoriach | 12 x 30 = 360 | \n",
+ "
\n",
+ " \n",
+ " Sprinty | 6 x 10 = 60 | \n",
+ "
\n",
+ " \n",
+ " Ocena końcowa za wynik projektu | 180 | \n",
+ "
\n",
+ " \n",
+ " Suma | 600 | \n",
+ "
\n",
+ "
\n",
+ "\n",
+ "## Ocena projektu\n",
+ "\n",
+ "Na przedostatnich zajęciach z laboratorium w dniu 25 stycznia 2022 opiekun projektu decyduje, czy projekt spełnił swoje założenia. Zgodnie z propozycją z wykładu projekt powinien znajdować się na 6. poziomie gotowości technologicznej:\n",
+ "\n",
+ "* Poziom 5.\n",
+ " * Zweryfikowano działanie w warunkach zbliżónych do rzeczywistego (np. przeprowadzono testowanie prototypu wdrożónego na serwerze WMI).\n",
+ "* Poziom 6.\n",
+ " * Dokonano demonstracji działania w warunkach zbliżónych do rzeczywistych (np. zademonstrowano wdrożony prototyp z interakcją użytkowników).\n",
+ " \n",
+ "Jeśli projekt nie spełnia założeń, to ocena końcowa za wynik projektu wynosi 0 punktów (na 180).\n",
+ "\n",
+ "Jeśli projekt spełnia założenia, to opiekun projektu proponuje ocenę w skali do 180 punktów.\n",
+ "\n",
+ "Proponowane składowe oceny implementacji systemu\n",
+ "\n",
+ "\n",
+ " \n",
+ " Za co? | Maksymalna liczba punktów do zdobycia | \n",
+ "
\n",
+ " \n",
+ " Functionality (funkcjonalność) | 40 | \n",
+ "
\n",
+ " \n",
+ " Usability (Użyteczność) | 30 | \n",
+ "
\n",
+ " \n",
+ " Reliability (niewystępowanie błędów) | 20 | \n",
+ "
\n",
+ " \n",
+ " Performance (wydajność: zużycie zasobów, czas odpowiedzi) | 10 | \n",
+ "
\n",
+ " \n",
+ " Supportability (możliwość instalacji i działania na różnych platformach) | 10 | \n",
+ "
\n",
+ " \n",
+ " Podręcznik użytkowania lub pomocy dla użytkownika) | 20 | \n",
+ "
\n",
+ " \n",
+ " Raport z testowania wersji końcowej | 20 | \n",
+ "
\n",
+ " \n",
+ " Raport użyteczności wersji końcowej | 20 | \n",
+ "
\n",
+ " \n",
+ " Documentation (zebranie wytworzonych dokumentów systemu oraz podręcznika i raportów (testowania i użyteczności)) | 10 | \n",
+ "
\n",
+ " \n",
+ " SUMA | 180 | \n",
+ "
\n",
+ "
\n",
+ " \n",
+ "Ocena proponowana przez opiekuna jest weryfikowana przez komisję, w skład której wchodzą wszyscy opiekunowie po demonstracji publicznej projektu w dniu 2 lutego 2022.\n",
+ "\n",
+ "## Demontstacje projektów\n",
+ "\n",
+ "Demonstracje publiczne projektów odbędą się w dniu 2 lutego 2022. Demonstracje trwać będą sumarycznie około trzech godzin (po 10 minut na system). Godziny demonstracji zostaną uzgodnione z prowadzącymi inne przedmioty - mniej więcej między godziną 14.30 i 17.30.\n",
+ "\n",
+ "## Proponowana skala ocen na przedmiocie PBR\n",
+ "\n",
+ " \n",
+ " Liczba punktów | Ocena | \n",
+ "
\n",
+ " \n",
+ " 500-600 | 5 | \n",
+ "
\n",
+ " \n",
+ " 450-499 | 4,5 | \n",
+ "
\n",
+ " \n",
+ " 400-449 | 4 | \n",
+ "
\n",
+ " \n",
+ " 350-399 | 3,5 | \n",
+ "
\n",
+ " \n",
+ " 300-349 | 3 | \n",
+ "
\n",
+ "
\n"
+ ]
+ }
+ ],
+ "metadata": {
+ "kernelspec": {
+ "display_name": "Python 3",
+ "language": "python",
+ "name": "python3"
+ },
+ "language_info": {
+ "codemirror_mode": {
+ "name": "ipython",
+ "version": 3
+ },
+ "file_extension": ".py",
+ "mimetype": "text/x-python",
+ "name": "python",
+ "nbconvert_exporter": "python",
+ "pygments_lexer": "ipython3",
+ "version": "3.8.5"
+ }
+ },
+ "nbformat": 4,
+ "nbformat_minor": 4
+}
diff --git a/Organizacja zajęć.ipynb b/Organizacja zajęć.ipynb
deleted file mode 100644
index 5d42dc2..0000000
--- a/Organizacja zajęć.ipynb
+++ /dev/null
@@ -1,112 +0,0 @@
-{
- "cells": [
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "# Organizacja zajęć na przedmiocie Projekt badawczo-rozwojowy"
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "## Projekt badawczo-rozwojowy (PBR)\n",
- "## Laboratorium przedmiotu SYI\n",
- "Projekt badawczo-rozwojowy to przedmiot prowadzony w formie laboratoriów dla studentów II semestru studiów magisterskich na kierunku Informatyka.\n",
- "Wskazane jest, aby projekt badawczo-rozwojowy przyczyniał się do rozwoju prac magisterskich członków zespołu.\n",
- "\n",
- "Studenci Informatyki współpracują ze studentami Analizy i Przetwarzania Danych, tworząc razem zespoły o liczności od trzech do pięciu studentów. Aby umożliwić taką współpracę, laboratoria z przedmiotów SYI i PBR prowadzone są w ten sam dzień tygodnia i o tej samej godzinie. Studenci obu kierunków współpracują w tworzeniu wspólnego projektu badawczo-rozwojowego. \n",
- "\n",
- "Zespół projektowy powinien zatem składać się ze studentów obu kierunków (idealnie: dwóch studentów informatyki i dwóch studentów analizy danych). Skład zespołów może się kształtować podczas pierwszych trzech laboratoriów. Począwszy od laboratorium nr 4 studenci pracują w stałych zespołach.\n",
- "\n",
- "Osobą oceniającą pracę całego zespołu projektowego jest opiekun projektu badawczo-rozwojowego. \n",
- "\n",
- "Opiekunowie otrzymują od wykładowcy przedmiotu PPB proponowane scenariusze wszystkich laboratoriów przedmiotu PBR wraz z wytycznymi dotyczącymi oceniania pracy studentów. Opiekun projektu ma jednak prawo odstąpić od proponowanych scenariuszy - częściowo lub w całości, dostosowując przebieg laboratorium do specyfiki projektu. W każdym wypadku wymaga się jednak, aby praca projektowa była udokumentowana.\n",
- "\n",
- "## Ocena końcowa z przedmiotu PBR\n",
- "Studentom informatyki ocenę końcową z laboratorium wystawia opiekun projektu badawczo-rozwojowego.\n",
- "\n",
- "## Umiejętności nabywane podczas przedmiotu PBR\n",
- "Student informatyki powinien nabyć następujące umiejętności:\n",
- "* tworzenie koncepcji projektu badawczo-rozwojowego,\n",
- "* implementacja systemu informatycznego w metodyce zwinnej,\n",
- "* stosowanie praktyki ciągłej integracji w rozwoju systemu informatycznego,\n",
- "* wdrożenie systemu będącego wynikiem projektu badawczo-rozwojowego w praktyce gospodarczej.\n",
- "\n",
- ]
- },
- {
- "cell_type": "markdown",
- "metadata": {},
- "source": [
- "## Organizacja wykładów PPB oraz SYI\n",
- "Wykłady z przedmiotów SYI i PBR prowadzone są równolegle, aby umożliwić współpracę studentów obu kierunków podczas laboratoriów PRB oraz SYI.\n",
- "\n",
- "### Zasady zaliczenia wykładu\n",
- "Wykład może być zaliczony albo na podstawie punktów uzyskanych za rozwiązywanie testów podawanych na wykładzie, albo poprzez egzamin końcowy. \n",
- "\n",
- "Za prawidłowe odpowiedzi na pytania testowe podawane podczas wykładu studenci otrzymują punkty (1 punkt za prawidłową odpowiedź). Testy rozwiązywane mogą być na dowolnych urządzeniach, które dysponują przeglądarką internetową. System do testów jest osiągalny pod adresem: \n",
- " **cybertest2.wmi.amu.edu.pl** \n",
- "Logowanie do systemu odbywa się za pomocą standardowych danych dostępowych na WMI. \n",
- "\n",
- "Wykładowca zobowiązuje się do przeprowadzenia testów z minimum 120 pytaniami podczas całego kursu (standardowo: 5 pytań powtórkowych na początku wykładu i 5 pytań na końcu wykładu). \n",
- "\n",
- "### Zwolnienia z egzaminu\n",
- "Student zwolniony jest z egzaminu z oceną dostateczny plus lub wyższą, wynikającą z punktów zdobytych za rozwiązanie zadań testowych podawanych na wykładach. \n",
- "\n",
- "Studenci niespełniający powyższego kryterium zdają egzamin obejmujący materiał przedstawiany na wykładach. Studenci mogą zdawać egzamin również w sytuacji, gdy nie satysfakcjonuje ich ocena uzyskana na podstawie zdobytych punktów.\n",
- "\n",
- "### Skala ocen z wykładu \n",
- "\n",
- " \n",
- " Liczba prawidłowych odpowiedzi | Ocena | \n",
- "
\n",
- " \n",
- " 100-120 | 5 | \n",
- "
\n",
- " \n",
- " 90-99 | 4,5 | \n",
- "
\n",
- " \n",
- " 80-89 | 4 | \n",
- "
\n",
- " \n",
- " 70-79 | 3,5 | \n",
- "
\n",
- " \n",
- " poniżej | egzamin | \n",
- "
\\n\n",
- "
"
- ]
- },
- {
- "cell_type": "code",
- "execution_count": null,
- "metadata": {},
- "outputs": [],
- "source": []
- }
- ],
- "metadata": {
- "kernelspec": {
- "display_name": "Python 3",
- "language": "python",
- "name": "python3"
- },
- "language_info": {
- "codemirror_mode": {
- "name": "ipython",
- "version": 3
- },
- "file_extension": ".py",
- "mimetype": "text/x-python",
- "name": "python",
- "nbconvert_exporter": "python",
- "pygments_lexer": "ipython3",
- "version": "3.7.6"
- }
- },
- "nbformat": 4,
- "nbformat_minor": 4
-}
diff --git a/materiały na PPB (wykład)/.ipynb_checkpoints/11_aspekty_użyteczności-checkpoint.ipynb b/materiały na PPB (wykład)/.ipynb_checkpoints/11_aspekty_użyteczności-checkpoint.ipynb
index 833e0e6..1e2cbaa 100644
--- a/materiały na PPB (wykład)/.ipynb_checkpoints/11_aspekty_użyteczności-checkpoint.ipynb
+++ b/materiały na PPB (wykład)/.ipynb_checkpoints/11_aspekty_użyteczności-checkpoint.ipynb
@@ -167,6 +167,7 @@
" * Wskazówka: wykonaj diagram Venna\n",
"\n",
"\n",
+ "\n",
"(Przykładowy diagram Venna, Źródło: Matt Lacey, \"Postaw na użyteczność\")\n",
"\n",
"* Jakie są grupy użytkowników?\n",
diff --git a/materiały na PPB (wykład)/09_testowanie_systemowe_i_akceptacyjne.ipynb b/materiały na PPB (wykład)/09_testowanie_systemowe_i_akceptacyjne.ipynb
index 0f633e3..0c3e93f 100644
--- a/materiały na PPB (wykład)/09_testowanie_systemowe_i_akceptacyjne.ipynb
+++ b/materiały na PPB (wykład)/09_testowanie_systemowe_i_akceptacyjne.ipynb
@@ -60,7 +60,7 @@
"source": [
"## 2.1. Testowanie funkcjonalne (functional testing)\n",
"**Testowanie funkcjonalne** ma na celu wykazanie rozbieżności między programem a jego specyfikacją zapisaną w postaci wymagań funkcjonalnych lub przypadków użycia.\n",
- " * Przypadki testowe (scenariusze testowe) wielokrotnie tworzy się na podstawie przypadków użycia.\n",
+ " * Przypadki testowe (scenariusze testowe) często tworzy się na podstawie przypadków użycia.\n",
" * Podstawowa zasada:Im więcej błędów wykryto w pewnej funkcji programu, tym (prawdopodobnie) większą liczbę błędów ona jeszcze ukrywa.\n",
" * Testowanie funkcjonalne może odbywać się na różnych poziomach szczegółowości:\n",
" * testy dymne\n",
@@ -76,7 +76,7 @@
"**Testy dymne** (ang. smoke tests) to powierzchowne testy pozwalające wykazać błędy krytyczne,\n",
" * Przykładem testu dymnego może być test CRUD (Create, Read, Update, Delete).\n",
" \n",
- "**Przykład opisu testów dymnych:**\n",
+ "**Przykład opisu testów dymnych (system automatycznego tłumaczenia dokumentów):**\n",
""
]
},
@@ -85,7 +85,7 @@
"metadata": {},
"source": [
"### Testy zdroworozsądkowe\n",
- "**Testy zdroworozsądkowe** mają wykazać, że aplikacja nie działa zgodnie ze stawianymi przed nią wymaganiami.\n",
+ "**Testy zdroworozsądkowe** (ang. sanity tests) mają wykazać, że aplikacja nie działa zgodnie ze stawianymi przed nią wymaganiami.\n",
">\"Smoke test określa, czy w ogóle coś działa, a sanity test - czy działa tak, jak ma działać”.\n",
"\n",
"**Przykład przypadków testowych na poziomie testowania zdroworozsądkowego:**\n",
@@ -100,7 +100,7 @@
"**Testy regresywne** to szczegółowe testy, pozwalające wykazać, że w aplikacji powstały nieznane błędów będące wynikiem wprowadzonych zmian.\n",
"\n",
"**Przykład przypadku testowego na poziomie testowania regresywnego:**\n",
- ""
+ ""
]
},
{
@@ -133,15 +133,34 @@
"cell_type": "markdown",
"metadata": {},
"source": [
- "## 2.3. Testowanie przeciążeń (load testing)\n",
- "**Przeciążenie** to skumulowanie w krótkim czasie dużej liczby jednocześnie działających użytkowników lub przeprowadzanych transakcji. \n",
- "\n",
+ "## 2.3. Testowanie przeciążeń (load testing)"
+ ]
+ },
+ {
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
+ "\n",
+ "
Przeciążenie
\n",
+ " \n",
+ "Przeciążenie to skumulowanie w krótkim czasie dużej liczby jednocześnie działających użytkowników lub przeprowadzanych transakcji. \n",
+ ""
+ ]
+ },
+ {
+ "attachments": {},
+ "cell_type": "markdown",
+ "metadata": {},
+ "source": [
"Celem **testowania przeciążeń** jest zweryfikowania działania systemu przy wysokim obciążeniu.\n",
" * Przykładowy scenariusz testowania przeciążeń:\n",
" * Nagranie ciągu operacji wykonywanych przez jednego klienta (np. \u000b",
"w postaci makra)\n",
" * Odtworzenie nagranego ciągu operacji dla wybranej (dużej) liczby klientów\n",
- " * Analiza raportu\n",
+ " * Analiza raportu \n",
+ "\n",
+ " * Lista narzędzi do testowania przeciążeń: \n",
+ "https://testerzy.pl/baza-wiedzy/narzedzia/10-najlepszych-narzedzi-do-testow-wydajnosci\n",
"\n",
"**Przykład raportu tekstowego z testu przeciążeń systemu tłumaczenia:**\n",
"\n",
diff --git a/materiały na PPB (wykład)/11_aspekty_użyteczności.ipynb b/materiały na PPB (wykład)/11_aspekty_użyteczności.ipynb
index 833e0e6..1e2cbaa 100644
--- a/materiały na PPB (wykład)/11_aspekty_użyteczności.ipynb
+++ b/materiały na PPB (wykład)/11_aspekty_użyteczności.ipynb
@@ -167,6 +167,7 @@
" * Wskazówka: wykonaj diagram Venna\n",
"\n",
"\n",
+ "\n",
"(Przykładowy diagram Venna, Źródło: Matt Lacey, \"Postaw na użyteczność\")\n",
"\n",
"* Jakie są grupy użytkowników?\n",