Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 5
Регистрация: 01.10.2013
Сообщений: 203

Создание нескольких процессов при подсчёте рядов тейлора

26.03.2015, 13:39. Показов 848. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задачка такая: есть такая функция: y = sin(2*PI*i / N), где i = {0, N-1}.
Нужно найти массив, в котором буду содержаться результаты суммирования каждого ряда, но сделать это нужно с созданием отдельного процесса при подсчёте очередного ряда.
Написал обычную программу без многопроцессорности:
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
#include <stdio.h>
#include <math.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
 
#define M_PI 3.14159
 
long int factorial(int m)
{
    if (m == 0 || m == 1) return (1);
    else      return (m*factorial(m - 1));
}
double power(double x, int n)
{
    double val = 1;
    int i;
    for (i = 1; i <= n; i++)
    {
        val *= x;
    }
    return val;
}
 
 
void taylorSeries(int N, int n){
    double *arr;
    arr = (double*)calloc(N, sizeof(double));
    for (int i = 0; i <= N - 1; i++){
        double val = 0;
        for (int j = 0; j < n; j++){
            double p = power(-1, j);
            double px = power((2 * M_PI * i / N), 2 * j + 1);
            long fac = factorial(2 * j + 1);
            val += p*px / fac;
        }
        arr[i] = val;
    }
 
    double sum = 0;
    for (int i = 0; i <= N - 1; i++){
        sum += arr[i];
    }
    printf("%.25f", sum);
 
}
 
int main()
{
    taylorSeries(256, 5);
    _getch();
}
С созданием процессов туго.. знаю, что использовать fork(), а вот как ещё разбираюсь, пока безуспешно.

Добавлено через 13 часов 55 минут
что-то понемногу получается, только цикл не заканчивается
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <sys/wait.h>
#include <fcntl.h>
#include <unistd.h>
#include <errno.h>
 
 
long int factorial(int m)
{
    if (m == 0 || m == 1) return (1);
    else      return (m*factorial(m - 1));
}
double power(double x, int n)
{
    double val = 1;
    int i;
    for (i = 1; i <= n; i++)
    {
        val *= x;
    }
    return val;
}
 
 
void taylorSeries(int N, int n)
{
    pid_t pid;
    int i,j;
    double M_PI = 3.14159;
    double *arr;
    arr = (double*)calloc(N, sizeof(double));
    for (i = 0; i <= N - 1; i++)
    {
        pid = fork();
        if (pid == 0)
        {
            double val = 0;
            for (j = 0; j < n; j++)
            {
                double p = power(-1, j);
                double px = power((2 * M_PI * i / N), 2 * j + 1);
                long fac = factorial(2 * j + 1);
                val += p*px / fac;
            }
            printf("PID=%d and arr[%d]=%.25f\n", getpid(),i, val);
            arr[i] = val;
 
        }
        if (pid!=0)
            wait(NULL);
        
    }
 
    
 
    double sum = 0;
    for (i = 0; i <= N - 1; i++)
    {
        sum += arr[i];
    }
    printf("%.25f\n", sum);
 
}
 
int main()
{
    taylorSeries(256, 5);
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.03.2015, 13:39
Ответы с готовыми решениями:

Выводит крокозяблы при подсчёте ряда Тейлора
#include&lt;iostream.h&gt; #include&lt;math.h&gt; #include&lt;windows.h&gt; long double fact(int N) { if(N &lt; 0) return 0; ...

Объединение рядов при разложении в ряд Тейлора
Объясните, пожалуйста, переход в равенстве с объединением рядов (пример из книги) \frac{e}{2}...

использование ряда Тейлора в подсчете логарифма
У меня задание с использованием ряда Тейлора создайте программу для подсчета натурального логарифма. Что то вроде этого...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.03.2015, 13:39
Помогаю со студенческими работами здесь

Вычисление Рядов Тейлора
Добрый день, уважаемые и многоуважаемые пользователи форума:) Помогите с решением одной задачи (сам не могу решить, т. к. необходимо...

Калькулятор тригонометрических функций на основе рядов Тейлора
Как сделать так что бы перевод из градусов в радианы был в другом модуле ? public uint per { get; set; } public...

Сложение или вычитание двух рядов Тейлора
Всем доброго дня! Пытаюсь сложить результат вычисления двух рядов тейлора. Вычисляет неправильно, видно даже визуально. Подскажите, в чем...

Вычисление sin и cos с использованием рядов Тейлора
Нужно создать калькулятор для подсчета sin и cos с помощью рядов Тейлора.Вводить нужно значения в градусах.Точность нужна до 4 знака после...

Нахождение sin и cos с использованием рядов Тейлора
Нужно создать калькулятор для подсчета sin и cos с помощью рядов Тейлора.Вводить нужно значения в градусах.Точность нужна до 4 знака после...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru