Перейти к содержанию

Промежуточные Значения Массива


АртёмЪ

Рекомендуемые сообщения

Здрасте!

Как расчитать помежуточные значения в массиве?

int b[10] = {1000,1500,2000,2500,3000,3500,4000,4500,5000,6000}; //массив B

int a[10] = {10,15,21,25,25,30,25,25,20,15}; // массив A

Массив B это обороты мотора, допустим у нас 1700об. Как найти промежуточное значение в массиве A, тоесть оно будет между 15 и 21 ?

Или может есть какие-нибудь другие варианты решения данной задачи?

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

тоесть оно будет между 15 и 21
А сколько конкретно оно должно быть ? :)

Сравнивайте обороты с значениями в массиве, инкрементируя индекс массива. Как только значение в массиве будет больше, значит Вы нашли нужный индекс. И по этому индексу выдёргивайте значение из второго массива.

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

АртёмЪ, аппроксимировать нужно. Например, между значениями 25 и 25 наверняка есть горб, а между 25 и 30 - впадина. Нарисуйте график функции А=f по точкам и соедините точки плавной линией.

Изменено пользователем Григорий Т.

Никогда не спорьте с дураком - люди могут не заметить между вами разницы

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для заряда литий-железофосфатных (LiFePO4) аккумуляторов

Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ очень важен контроль процесса заряда и разряда для избегания воздействия внешнего зарядного напряжения после достижения 100% заряда. Инженеры КОМПЭЛ подготовили список таких решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

тоесть оно будет между 15 и 21
А сколько конкретно оно должно быть ? :)

Примерно столько.

b=1700об, Опредиляем соседние значения(КАК программно?)

2000-1500=500

1700-1500=200

500/200=2.5

21-15=6

6/2.5=2.4

15+2.4=17.4

В математику можно не вникать.

Сравнивайте обороты с значениями в массиве, инкрементируя индекс массива. Как только значение в массиве будет больше, значит Вы нашли нужный индекс.

Вот тут у меня и проблема. Я не понимаю как это сделать. В програмиовании я почти 0.

АртёмЪ, аппроксимировать нужно. Например, между значениями 25 и 25 наверняка есть горб, а между 25 и 30 - впадина. Нарисуйте график функции А=f по точкам и соедините точки плавной линией.

Никаких горбов и впадин, такая плавность не нужна, достаточно просто линейные участки от одного значения к другому

Ссылка на комментарий
Поделиться на другие сайты

Сравнительное тестирование аккумуляторов EVE Energy и Samsung типоразмера 18650

Инженеры КОМПЭЛ провели сравнительное тестирование аккумуляторов EVE и Samsung популярного для бытовых и индустриальных применений типоразмера 18650. 

Для теста были выбраны аккумуляторы литий-никельмарганцевой системы: по два образца одного наименования каждого производителя – и протестированы на двух значениях тока разряда: 0,5 А и 2,5 А. Испытания проводились в нормальных условиях на электронной нагрузке EBD-USB от ZKEtech, а зарядка осуществлялась от лабораторного источника питания в режиме CC+CV в соответствии с рекомендациями в даташите на определенную модель. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Если добавить элемент b[9]=5500; b[10]=6000 то вычислять соседние точки станет не нужно, можно будет воспользоваться функциями деления/остатка и соответственно находить номер.

Неоптимизированный вариант решения:

i=x*2/1000-2;

x0=(i+2)*1000/2;

y=a+(a[i+1]-a)*(x-x0)/500;

//все числа - целые, скорее всего unsigned int

в случае добавления элемента и соответствующего увеличения массивов. Даже в таком варианте используется всего 2 деления на константу, что равносильно умножению на другую константу. Операции сложения-вычитания выполняются намного быстрее, поэтому существенной роли не сыграют.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Литиевые аккумуляторы EVE Energy и решения для управления перезаряжаемыми источниками тока (материалы вебинара)

Опубликованы материалы вебинара Компэл, посвященного литиевым аккумуляторам EVE Energy и решениям для управления перезаряжаемыми источниками тока.

На вебинаре мы представили информацию не только по линейкам аккумуляторной продукции EVE, но и по решениям для управления ею, что поможет рассмотреть эти ХИТ в качестве дополнительной альтернативы для уже выпускающихся изделий. Также рассмотрели нюансы работы с производителем и сервисы, предоставляемые Компэл по данной продукции. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Если добавить элемент b[9]=5500; b[10]=6000 то вычислять соседние точки станет не нужно, можно будет воспользоваться функциями деления/остатка и соответственно находить номер.

Упростить не получится, так как значения в массивах будут часто меняться.

Я тут чего-то намудрил

#include <mega16.h>

int a[2] = {1,254};

int b[2] = {1,254};

int c,d,i,e,f,g,q,w;

void main()

{

DDRD=255;

while(1){

d = 128;

if(a[0]<= d <a[1]) {i=b[0], c=b[1];}

e = a[1] - a[0];

f = d - a[0];

g = e/f;

q = b[1] - b[0];

w = q/g;

PORTD = b[0] + w ;

} }

Очень упрощенный вариант всего для одного диапазона. Такое придеться писать для каждого диапазона или как-то попытаться упростить.

Вобщем этот кусок работает и значения почти(оно ж не умеет считать после запятой) правильные выводит, но после 127 и до конца на выходе всегда 254, надо разбираться.

Разобрался с корявостью счета, домножил на 10 в двух местах, а для большей точности, можно и на 100.

PORTD = b[0] + (((b[1] - b[0])*10)/(((a[1] - a[0])*10)/(d - a[0]))) ;

Изменено пользователем АртёмЪ
Ссылка на комментарий
Поделиться на другие сайты

Литиевые батарейки и аккумуляторы от мирового лидера  EVE в Компэл

Компания Компэл, официальный дистрибьютор EVE Energy, бренда №1 по производству химических источников тока (ХИТ) в мире, предлагает продукцию EVE как со склада, так и под заказ. Компания EVE широко известна в странах Европы, Америки и Юго-Восточной Азии уже более 20 лет. Недавно EVE была объявлена поставщиком новых аккумуляторных элементов круглого формата для электрических моделей «нового класса» компании BMW.

Продукция EVE предназначена для самого широкого спектра применений – от бытового до промышленного. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

Массив значений числа оборотов будет меняться?!

Писать для каждого диапазона отдельную процедуру - очень плохая идея.

Чем не устраивает мой алгоритм, реализующий то же самое, но для все хуказанных частот?

В Вашем коде

* * *
void main(){
DDRD=255;//лучше использовать двоичную или шестнадцатеричную запись, впрочем на работу это не повлияет
while(1){
 d = 128;//это значение числа оборотов?
 if(a[0]<= d <a[1]){ //условие будет работать неправильно, так как выражение (d<a[1])уже не int а скорее bool (не уверен в каком формате хранятя результаты логических выражений)
  i=b[0];//переменная i нигде не используется
  c=b[1];//аналогично
 }
 e = a[1] - a[0];
 f = d - a[0];
 g = e/f;  //при делении int/int дробная часть отбрасывается.
 q = b[1] - b[0];
 w = q/g;  //логичнее было бы w=q*f/e
 PORTD = b[0] + w ;
}
}

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Массив значений числа оборотов будет меняться?!

Да, для каждой машины индивидуально будет настраиваться.

В ваш алгоритм буду завтра вникать, посмотрим как там что.

Спасибо за коментарии к моему коду.

Ссылка на комментарий
Поделиться на другие сайты

Вот. Работает

#include <mega16.h>

int a[10] ={500,1000,1500,2000,2500,3000,3500,4000,4500,5000};

int b[10] = {10, 15 ,20, 20, 20, 17, 15, 12, 10, 5};

int d,i;

void main()

{

DDRD=0b11111111;

while(1){

d = 1200; //обороты

i=0;

while (a < d )

{i++;}

PORTD = b[i-1] + (((b - b[i-1])*10)/(((a - a[i-1])*10)/(d - a[i-1]))) ;

}}

Ссылка на комментарий
Поделиться на другие сайты

PORTD = b[i-1] + (b - b[i-1])*(d-a[i-1])/(a - a[i-1]);

Так оно чуть побыстрее и точнее будет.

Цикл подбора i лучше бы переписать. Он работает, но нет проверок на конец массива.

for(i=0;(i<10)&&(a<d);i++); - например так.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

АртёмЪ, я честно не въехал, зачем тебе массив с данными обротов/мин.? Эти значения, выбираются для индикации? Или для чего. Обычно замеры частоты вращения делаются в реальном времени между метками датчика. Эти же значения (с откинутыми лишними нулями) являются указателем индекса значений, соответствующих данной частоте. У тебя проглядывается что-то перенавороченное (или мне это кажется от непоняток).

Ссылка на комментарий
Поделиться на другие сайты

АртёмЪ, я честно не въехал, зачем тебе массив с данными обротов/мин.? Эти значения, выбираются для индикации? Или для чего. Обычно замеры частоты вращения делаются в реальном времени между метками датчика. Эти же значения (с откинутыми лишними нулями) являются указателем индекса значений, соответствующих данной частоте. У тебя проглядывается что-то перенавороченное (или мне это кажется от непоняток).

Ненененене. Всё не так как вы думаете. Это будет контролер управления наддувом. Тоесть массив с оборотами и массив с желаемыми значениями наддува. Естесвенно, для каждой машины эти значения будут свои.

На самом деле, массивов с давлением наддува будет больше, на каждую передачу свой.

COKPOWEHEU, спасибо.

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...