Skip to main content

Adding a cap to a logarithmic regression

I'm running a log regression to model out reach curves. A typical reach curve looks like: reach curve

So using a log regression seems the obvious choice. The reach curves are based on historical activity, but I have some additional knowledge of the total user count, so I know for certain that the reach can never exceed a certain number.

I am having a hard time blending a modelled log curve with a known hard cap. Ideally I think I should add some modifier that increases the diminishing effect as the output approaches the known cap, to help preserve the curve on the lower values (where most the activity happens) while adding in the known cap to prevent the model from returning values where the reach is 125% of all users.

Currently i'm using scipy optimize, i've added a ton of synthetic data at the known max to try and force this model to respect the max, but I think i'm going down the wrong road here:

current model

I feel like I need another function that takes the output of this one, and adds a penalty increasing in strength as the value approaches the known max, but I can't seem to get it to work, my curve keeps going negative or the blend comes out really jarring like a hard cap, any thoughts on how to approach this?



source https://stackoverflow.com/questions/77448229/adding-a-cap-to-a-logarithmic-regression

Comments

Popular posts from this blog

How to show number of registered users in Laravel based on usertype?

i'm trying to display data from the database in the admin dashboard i used this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count(); echo $users; ?> and i have successfully get the correct data from the database but what if i want to display a specific data for example in this user table there is "usertype" that specify if the user is normal user or admin i want to user the same code above but to display a specific usertype i tried this: <?php use Illuminate\Support\Facades\DB; $users = DB::table('users')->count()->WHERE usertype =admin; echo $users; ?> but it didn't work, what am i doing wrong? source https://stackoverflow.com/questions/68199726/how-to-show-number-of-registered-users-in-laravel-based-on-usertype

Why is my reports service not connecting?

I am trying to pull some data from a Postgres database using Node.js and node-postures but I can't figure out why my service isn't connecting. my routes/index.js file: const express = require('express'); const router = express.Router(); const ordersCountController = require('../controllers/ordersCountController'); const ordersController = require('../controllers/ordersController'); const weeklyReportsController = require('../controllers/weeklyReportsController'); router.get('/orders_count', ordersCountController); router.get('/orders', ordersController); router.get('/weekly_reports', weeklyReportsController); module.exports = router; My controllers/weeklyReportsController.js file: const weeklyReportsService = require('../services/weeklyReportsService'); const weeklyReportsController = async (req, res) => { try { const data = await weeklyReportsService; res.json({data}) console...

How to split a rinex file if I need 24 hours data

Trying to divide rinex file using the command gfzrnx but getting this error. While doing that getting this error msg 'gfzrnx' is not recognized as an internal or external command Trying to split rinex file using the command gfzrnx. also install'gfzrnx'. my doubt is I need to run this program in 'gfzrnx' or in 'cmdprompt'. I am expecting a rinex file with 24 hrs or 1 day data.I Have 48 hrs data in RINEX format. Please help me to solve this issue. source https://stackoverflow.com/questions/75385367/how-to-split-a-rinex-file-if-i-need-24-hours-data